Форум программистов, компьютерный форум CyberForum.ru

Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
Chainik!
1 / 1 / 1
Регистрация: 10.11.2008
Сообщений: 43
16.09.2012, 21:06     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза #1
Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.09.2012, 21:06     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза
Посмотрите здесь:

C++ максимальное из чисел, встречающихся в заданной матрице более одного раза.(исправить 1 ошибку)
Найти максимальное из чисел встречающихся в матрице более одного раза. Сделать используя указатели и классы C++
C++ Максимальное из чисел, встречающихся в заданной матрице более одного раза
Определить максимальное из значений, встречающихся в заданной матрице более одного раза C++
C++ Двумерный массив. Найти: максимальное из чисел, встречающихся в заданной матрице более одного раза
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
igorrr37
 Аватар для igorrr37
1593 / 1221 / 118
Регистрация: 21.12.2010
Сообщений: 1,868
Записей в блоге: 7
16.09.2012, 23:56     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <algorithm>
 
int main()
{
    short  mx[][3] = {{-1,-2,3},{4,-1,6},{7,8,2}}, size = sizeof(mx) / sizeof(**mx);
    std::sort(*mx, *mx + size);
    for(int i = size - 1; i > 0; --i)
    {
        if(*(*mx + i) == *(*mx + i - 1))
        {
            std::cout << *(*mx + i) << std::endl;
            break;
        }
    }
    return 0;
}
Chainik!
1 / 1 / 1
Регистрация: 10.11.2008
Сообщений: 43
17.09.2012, 07:37  [ТС]     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза #3
Я так и не понял задание, объясните смысл??
Chainik!
1 / 1 / 1
Регистрация: 10.11.2008
Сообщений: 43
19.09.2012, 20:43  [ТС]     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза #4
Всё понял
Chainik!
1 / 1 / 1
Регистрация: 10.11.2008
Сообщений: 43
22.09.2012, 13:06  [ТС]     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза #5
Дана целочисленная произвольная матрица, Определить:
1)Количество строк, не содержащих не одного нулевого элемента
2)Максимальное из чисел, встречающихся в заданной матрице более одного раза.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#include "stdafx.h"
#include "iostream"
#include "conio.h"
#include "iomanip"
#include "ctime"
using namespace std;
//---------------------------------------------
void rand(int **arr, int n, int m)
{
    srand(time(NULL));
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
            *(*(arr + i) + j) = rand() % 9;
    }
}
//---------------------------------------------
void print(int **arr, int n, int m)
{
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
            cout << setw(3) << *(*(arr + i) + j);
        cout << "\n\n";
    }
}
//---------------------------------------------
int max_count(int *arr, int n)
{
    int max = arr[0];
    for(int i = 1; i < n; i++)
    {
        if(arr[i] > max)
            max = arr[i];
    }
    return max;
}
//---------------------------------------------
void count_kop(int *arr, int n)
{
    int *res = new int[n];
    int k = 0;
    for(int i = 0; i < n; i++)
    {
        int t = arr[i];
        int count = 0;
        for(int j = 0; j < n; j++)
        {
            if(t == arr[j])
                count++;
        }
        if(count != 1)
            res[k++] = arr[i];
    }
    cout << "\n\nМаксимальное из чисел, встречающихся в заданной матрице более одного раза: ";
    cout << max_count(res,k);
    delete []res;
}
//---------------------------------------------
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(0,"");
    int n, m, **arr, *res, k;
    cout << "Введите размер строк: ";
    cin >> n;
    cout << "\n\nВведите размер столбцов: ";
    cin >> m;
    arr = new int*[n];
    for(int i = 0; i < n; i++)
        *(arr + i) = new int[m];
    cout << "\n\nМатрица имеет вид: \n\n";
    rand(arr,n,m);
    print(arr,n,m);
    int count = 0;
    for(int i = 0; i < n; i++)
    {
        bool b = false;
        for(int j = 0; j < m; j++)
        {
            if(arr[i][j] == 0)
                b = true;
        }
        if(!b)
            count++;
    }
    cout << "\n\nКоличество строк, не содержащих нулевых элементов: " << count;
    k = 0;
    res = new int[n * m];
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
            res[k++] = arr[i][j];
    }
    count_kop(res,k);
    delete []res;
    for(int i = 0; i < n; i++)
        delete[] arr[i];
    delete []arr;
    _getch();
    return 0;
}
Yandex
Объявления
22.09.2012, 13:06     Дана произвольная матрица, определить: Максимальное из чисел, встречающихся в заданной матрице более одного раза
Ответ Создать тему
Опции темы

Текущее время: 00:57. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru