С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/25: Рейтинг темы: голосов - 25, средняя оценка - 4.76
0 / 0 / 0
Регистрация: 01.10.2013
Сообщений: 22

Максимальное из чисел встречающихся в заданной матрице более одного раза

20.05.2014, 10:44. Показов 5132. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть программа, она работает, но мне не понятен принцип, мог бы кто нибудь помочь?

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
#include "stdafx.h"
#include <iostream>
#include <locale>
#include <iomanip>
#include <math.h>
#include <conio.h>
#include <time.h>
using namespace std;
 
int _tmain()
{ setlocale(LC_ALL, "Russian");
  int const n = 4, m = 4;
    int matr[n][m];
 srand(time(NULL)); 
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++) 
        {    
            matr[i][j] = rand() % 20 + 1; 
        } 
    }
   cout << "Исходная матрица: \n";
    for(int i = 0; i < n; i++)
    {
        cout << endl;
        cout << "\t";
        for(int j = 0; j < m; j++)
        {
            cout << setw(3) << setiosflags(ios::left) << matr[i][j] << " " ;
        }
    }
 
    cout << "\n\n";
 
    /*максимальное из чисел, встречающихся в заданной матрице более одного раза*/
 
    int t, t1 = 0, r = 0, t2;
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
        {
            t2 = matr[i][j];
            matr[i][j] = 0;
    
            for(int k = 0; k < n; k++)
            {
                for(int f = 0; f < m; f++)
                {
                    if(t2 == matr[k][f])
                    {
                        t = matr[k][f];
                    }
                    else
                        r++;
                }
 
                if(t1 > t)
                    t = t1;
            }
 
            t1 = t;
            matr[i][j] = t2;
 
        }
    }
 
    double kof;
    kof = pow((double)n,4);
 
    if(r == kof)
        cout << "Однинаковых элементов нет!"<<endl;
    else
        cout << "Максимальное из встречающихся более 1 раза: " << t <<endl;
 
    system ("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.05.2014, 10:44
Ответы с готовыми решениями:

Максимальное из чисел, встречающихся в заданной матрице более одного раза
//Дана целочисленная прямоугольная матрица. Определить: //1) количество строк, не содержащих ни одного нулевого элемента; ...

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

Определить максимальное из чисел, встречающихся в заданной матрице более одного раза
Здравствуйте!Помогите пожалуйста решить задачу. Дана целочисленная матрица. Определить максимальное из чисел, встречающихся в заданной...

5
20.05.2014, 10:49

Не по теме:

Админы, предлагаю темы раскидывать по соответствующим веткам, а тут уже оверфлоу ... Например, все темы, подобные этой - это ветка простого 'С', а не С++. За одно и будет поддержана жизнь других веток, а то вопросы всех тематик сыпятся сюда... Не правильно же, согласитесь

0
6 / 6 / 5
Регистрация: 15.02.2013
Сообщений: 56
20.05.2014, 11:22
Както так:
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
#include "stdafx.h"
#include <iostream>
#include <locale>
#include <iomanip>
#include <math.h>
#include <conio.h>
#include <time.h>
using namespace std;
 
int _tmain()
{ setlocale(LC_ALL, "Russian");//Кодировка, чтобы отображались нормально русские символы в консоли
  int const n = 4, m = 4;//Константные переменные, объявление и инициализация
    int matr[n][m];//Объявление двумерного массива
 srand(time(NULL));//позволяет функции rand генерировать псевдослучайные значения
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++) 
        {    
            matr[i][j] = rand() % 20 + 1; //Заполняем массив случайными значениями
        } 
    }
   cout << "Исходная матрица: \n";//вывод строки
    for(int i = 0; i < n; i++)
    {
        cout << endl;//перевод строки
        cout << "\t";//табуляция
        for(int j = 0; j < m; j++)
        {
            cout << setw(3) << setiosflags(ios::left) << matr[i][j] << " " ;//все выводимые строки сокращаются до 3 //символов, далее выравнивание по левой стороне, вывод переменной
        }
    }
 
    cout << "\n\n";//перевод строки
 
    /*максимальное из чисел, встречающихся в заданной матрице более одного раза*/
 
    int t, t1 = 0, r = 0, t2;//обявление переменных
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
        {
            t2 = matr[i][j];//присваиваем t2 значение из элемента matr[i][j]
            matr[i][j] = 0;//обнуляем элемент 
    
            for(int k = 0; k < n; k++)
            {
                for(int f = 0; f < m; f++)
                {
                    if(t2 == matr[k][f])//если t2 равен элементу matr[k][f]
                    {
                        t = matr[k][f];//присваиваем значение элемента matr[k][f] переменной t
                    }
                    else//если не равен
                        r++;//увеличиваем r на 1
                }
 
                if(t1 > t)//если t1 больше t
                    t = t1;//присваиваем значение из t1 в t
            }
 
            t1 = t;//присваиваем t1 значение из t
            matr[i][j] = t2;//присваиваем элементу матрицы значение из t2
 
        }
    }
 
    double kof;//объявление переменной
    kof = pow((double)n,4);//возведение числа n(предварительно приведенное к типу double) в степень 4
 
    if(r == kof)//если r равно kof
        cout << "Однинаковых элементов нет!"<<endl;//вывод строки
    else//если не равно
        cout << "Максимальное из встречающихся более 1 раза: " << t <<endl;
 
    system ("pause");//пауза
    return 0;
}
Добавлено через 8 минут
А вообще странная прога, есть задание?
1
0 / 0 / 0
Регистрация: 01.10.2013
Сообщений: 22
20.05.2014, 11:25  [ТС]
найти максимальное из чисел, встречающихся в заданной матрице более одного раза
0
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
20.05.2014, 11:47
Цитата Сообщение от Ильгиз96 Посмотреть сообщение
if(r == kof)
Здесь сравниваются 2 числа с плавающей запятой.
Они практически никогда не равны друг-другу из-за ошибок округления.
C++
1
2
3
int kof;//объявление переменной
    kof = n*n*n*n;//возведение числа n в степень 4
     if(r == kof)//если r равно kof
0
2 / 1 / 1
Регистрация: 04.04.2020
Сообщений: 11
13.06.2020, 08:18
C++
1
2
3
4
5
6
7
8
9
10
11
if(t2 == matr[k][f])//если t2 равен элементу matr[k][f]
                    {
                        t = matr[k][f];//присваиваем значение элемента matr[k][f] переменной t
                    }
                    else//если не равен
                        r++;//увеличиваем r на 1
                }
 
                if(t1 > t)//если t1 больше t
                    t = t1;//присваиваем значение из t1 в t
            }
Но смотрите, если t2 не будет равен элементу матрице, то в строчке if(t1 > t), t будет содержать мусор, так как мы не присваивали ей значение
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.06.2020, 08:18
Помогаю со студенческими работами здесь

Определить максимальное из чисел, встречающихся в заданной матрице более одного раза
максимальное из чисел, встречающихся в заданной матрице более одного раза. Добрый вечер, есть программка, все компил., но после...

Определить максимальное из чисел, встречающихся в заданной матрице более одного раза
Есть код. 1 задание, где определяет количество строк, не содержащих ни одного нулевого элемента уже сделано. Помогите дописать код, чтобы...

Найти максимальное из чисел, встречающихся в заданной матрице более одного раза
дана целочисленная прямоугольная матрица определить: максимальное из чисел встречающихся в заданной матрице более одного раза ...

Двумерный массив. Найти: максимальное из чисел, встречающихся в заданной матрице более одного раза
Найти: максимальное из чисел, встречающихся в заданной матрице более одного раза Матрица: 2 4 7 6 5 8 9 34 43 4 34 53 45 345 3 6 5 56...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru