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

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

Восстановить пароль Регистрация
 
Wanee
52 / 52 / 13
Регистрация: 02.02.2011
Сообщений: 428
01.10.2011, 17:41     Определить количество чисел, встревающих в заданной матрице более одного раза #1
Дана целочисленная прямоугольная матрица. Определить:
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++ максимальное из чисел, встречающихся в заданной матрице более одного раза.(исправить 1 ошибку)
C++ Максимальное из чисел, встречающихся в заданной матрице более одного раза
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
52 / 52 / 13
Регистрация: 02.02.2011
Сообщений: 428
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,585
Записей в блоге: 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     Определить количество чисел, встревающих в заданной матрице более одного раза
Ответ Создать тему
Опции темы

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