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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Wanee
53 / 53 / 13
Регистрация: 02.02.2011
Сообщений: 427
#1

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

01.10.2011, 17:41. Просмотров 366. Ответов 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();
}
Как доработать программу для второго условия?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.10.2011, 17:41     Определить количество чисел, встревающих в заданной матрице более одного раза
Посмотрите здесь:

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

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

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

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

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

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

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

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

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

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

Найти максимально из чисел, встречающегося в матрице более одного раза - C++
Привет! Выполните задание,оформив каждый пункт с помощью функций,все необходимые данные должны передаваться в ф-ю в...

Найти максимальное из чисел встречающихся в матрице более одного раза. Сделать используя указатели и классы - C++
Ребята..помогите,пожалуйста.Надо решить задачу,а никак не выходит(даже не знаю..прочитала в книге все про указатели и не пойму как...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
challengerr
43 / 36 / 2
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 18:34     Определить количество чисел, встревающих в заданной матрице более одного раза #2
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++;
}
Другой вариант решения той же задачи: сохранять элементы в отдельный массив и сравнивать с содержимым массива.
Wanee
53 / 53 / 13
Регистрация: 02.02.2011
Сообщений: 427
01.10.2011, 18:58  [ТС]     Определить количество чисел, встревающих в заданной матрице более одного раза #3
Что то не идет. Вот я добавил код:
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();
}
challengerr
43 / 36 / 2
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 18:59     Определить количество чисел, встревающих в заданной матрице более одного раза #4
извините - выше чушь в коде написал, нужно делать через массив
Van111
кодер с++
208 / 187 / 4
Регистрация: 03.08.2011
Сообщений: 2,587
Записей в блоге: 12
01.10.2011, 19:06     Определить количество чисел, встревающих в заданной матрице более одного раза #5
ну вот к примеру тут я вручную вычислил размер масива и вместо 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++;
        }
    }
challengerr
43 / 36 / 2
Регистрация: 30.07.2008
Сообщений: 136
01.10.2011, 20:02     Определить количество чисел, встревающих в заданной матрице более одного раза #6
такой вариант
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);
}
Yandex
Объявления
01.10.2011, 20:02     Определить количество чисел, встревающих в заданной матрице более одного раза
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru