Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
54 / 54 / 23
Регистрация: 02.02.2011
Сообщений: 436

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

01.10.2011, 17:41. Показов 730. Ответов 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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
const int n = 5, m = 6;
 
 
 
void main()
{
    int a[m][n];
    bool b[m][n] = {};
    int j, i, k = 0, p = 0;
    bool z;
 
    srand(time(0));
    setlocale(LC_ALL, "");
 
    for(j = 0; j < m; j++)
        for(i = 0; i < n; i++) a[j][i] = rand() % 11;
    for(j = 0; j < m; j++)
    {
        for(i = 0; i < n; i++) cout << a[j][i] << ' ';
        cout << '\n';
    }
 
    for(j = 0; j < m; j++)
    {
        z = false;
        for(i = 0; i < n; i++)
            if(!a[j][i])
                z = true;
        if(z)
            k++;
    }
 
    cout << "Количество строк содержащих 0: " << k << '\n';    
 
    cin.get();
}
Как доработать программу для второго условия?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.10.2011, 17:41
Ответы с готовыми решениями:

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

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

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

5
44 / 37 / 6
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 18:34
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
kolvoonivelenentov=0;
for(j = 0; j < m; j++)
for(i = 0; i < n; i++) 
{
flag = 0;
for(k = i + 1; k < n && flag == 0; k++)
if (a[j][i] == a[j][k]) flag = 1;
for(k = j + 1; j < m && flag == 0; j++)
for(s = 0; i < n && flag == 0; i++) 
if (a[j][i] == a[k][s]) flag = 1;
if(flag == 1)
kolvoonivelenentov++;
}
Другой вариант решения той же задачи: сохранять элементы в отдельный массив и сравнивать с содержимым массива.
1
54 / 54 / 23
Регистрация: 02.02.2011
Сообщений: 436
01.10.2011, 18:58  [ТС]
Что то не идет. Вот я добавил код:
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
const int n = 3, m = 3;
 
void main()
{
    int a[m][n];
    bool b[m][n] = {};
    int j, i, k = 0, x = 0;
    bool z;
 
    srand(time(0));
    setlocale(LC_ALL, "");
 
    for(j = 0; j < m; j++)
        for(i = 0; i < n; i++) a[j][i] = rand() % 11;
    for(j = 0; j < m; j++)
    {
        for(i = 0; i < n; i++) cout << a[j][i] << ' ';
        cout << '\n';
    }
 
    for(j = 0; j < m; j++)
    {
        z = false;
        for(i = 0; i < n; i++)
            if(!a[j][i])
                z = true;
        if(z)
            k++;
    }
 
    cout << "Количество строк содержащих 0: " << k << '\n';
 
    int kolvoonivelenentov=0;
    int flag;
    for(j = 0; j < m; j++)
        for(i = 0; i < n; i++) 
        {
            flag = 0;
            for(k = i + 1; k < n && flag == 0; k++)
                if (a[j][i] == a[j][k]) flag = 1;
            for(k = j + 1; j < m && flag == 0; j++)
                for(int s = 0; i < n && flag == 0; i++) 
                    if (a[j][i] == a[k][s])
                        flag = 1;
            if(flag == 1)
                        kolvoonivelenentov++;
        }
 
    cout << "Количество элементов: " << kolvoonivelenentov << '\n';
    
    cin.get();
}
0
44 / 37 / 6
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 18:59
извините - выше чушь в коде написал, нужно делать через массив
1
290 / 193 / 23
Регистрация: 03.08.2011
Сообщений: 2,824
Записей в блоге: 12
01.10.2011, 19:06
ну вот к примеру тут я вручную вычислил размер масива и вместо masiv[5][6] можно **masiv
C++
1
2
3
4
5
6
7
8
9
10
    int  npovtr;
    int (*masiv)[6] = new int[5][6];
    for (int i=0; i<42;i++)
    {
        for(int ii=0; ii<=42;ii++)
        {
        if (i==ii) continue;
        if (**(masiv+i)==**(masiv+ii)) npovtr++;
        }
    }
1
44 / 37 / 6
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 20:02
такой вариант
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
const int n = 5, m = 6;
typedef struct l* pl;
struct l {pl pe;pl ne;int x;int cnt; l(){pe=NULL;ne=NULL;};};
class plfabrika {public: pl cr(){ return new l;};};
int main()
{
        int a[m][n];
        bool b[m][n] = {};
        int j, i, k = 0, p = 0;
        bool z; 
        srand(time(0));
        setlocale(LC_ALL, "");
 
        for(j = 0; j < m; j++)
                for(i = 0; i < n; i++) a[j][i] = rand() % 11;
        for(j = 0; j < m; j++)
        {
                for(i = 0; i < n; i++) cout << a[j][i] << ' ';
                cout << '\n';
        }
  
int st = 0;  
plfabrika fa;
pl ty, ct, g ;
for(j = 0; j < m; j++)
for(i = 0; i < n; i++){
if (st==0){ty = fa.cr();ct = fa.cr();ty->x=a[j][i]; ty->cnt=1;ct=ty; st=1;}
else  { g = ty; while (g->ne!=NULL && g->x != a[j][i]) g=g->ne;
if (g->x  == a[j][i]) {g->cnt++;} else{ pl nt = fa.cr(); nt->x = a[j][i]; nt->cnt=1; nt->pe = ct; (nt->pe)->ne = nt;ct = nt;}}    
}
int yu=0;g = ty; while (g->ne!=NULL){ if (g->cnt !=1) yu++;  g=g->ne;}
cout << yu << '\n';
g=ct; while(g->pe!=NULL) { g=g->pe; delete g->ne; g->ne=NULL;}
delete g;delete ct;delete ty; g =NULL; ct=NULL;ty=NULL;   
        
  cin.get();
  return(0);
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.10.2011, 20:02
Помогаю со студенческими работами здесь

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

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

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

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

Максимальное из чисел встречающихся в заданной матрице более одного раза
Есть программа, она работает, но мне не понятен принцип, мог бы кто нибудь помочь? #include &quot;stdafx.h&quot; #include...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
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. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru