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

Матрица - C++

Восстановить пароль Регистрация
 
[WRG]
 Аватар для [WRG]
50 / 50 / 9
Регистрация: 20.11.2011
Сообщений: 243
Записей в блоге: 1
17.05.2012, 06:57     Матрица #1
если в матрице количество нулей в столбиках возрастает, то нужно подсчитать общее количество нулей в матрице. если же наоборот, то надо найти столбик с максимальным количеством нулей.

проблема в функции f1(). функция проверяет, возрастает ли количество нулей от столбика к столбику.
она почему-то постоянно возвращает true, даже когда когда условие не выполняется. пробовал и закомментированым методом который чуть ниже самой функции, релзультат тот же.

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
102
103
#include <iostream>
#include <cstdlib>
using namespace std;
 
const int nMax = 5; //Размерность матрицы
int a[nMax+1][nMax] = {
    {1,1,1,1,0},
    {1,1,1,0,0},
    {1,1,0,0,0},
    {1,0,0,0,0},
    {0,0,0,0,0},
    {0,0,0,0,0}
};
 
 
void fill_array();
int zerocount(int count);
bool f1();
 
//-----------------------MAIN----------------------
 
int main()
{
    //fill_array();
    for (int i = 0; i < nMax; i++)
      {
          a[nMax][i] = zerocount(i);
      }
    cout << "\n";
    for (int i = 0; i < nMax; i++) cout << a[nMax][i] << " ";
    cout << "\n";
 
    if (f1)
    {
        cout << "f1 вернула true\n";
        int count = 0;
        cout << "count = " << count << "\n";
        for (int i = 0; i < nMax; i++)
          for (int j = 0; j < nMax; j++)
            if (a[i][j] == 0) count++;
        cout << "В матрице " << count << " элементов равны нулю\n";
    }
    else
    {
        cout << "f1 вернула false\n";
        int nb = 0, max = a[nMax][nb];   //nb - номер столбца
        for (int i = 1; i < nMax; i++)
          if (a[nMax][i] > max)
          {
              max = a[nMax][i];
              nb = i;
          }
        cout << "В " << nb << "-ом столбце максимально количество нулей";
    }
    return 0;
}
 
//---------------------END OF MAIN---------------------------
 
void fill_array()    //заполнение массива рандомными числами
{
    int i,j;
    srand(time(NULL));
    for (i = 0; i < nMax; i++)
      {
         for (j = 0; j < nMax; j++)
           {
              a[i][j] = rand() % 5;
              cout << a[i][j] << " ";
           }
         cout << "\n";
      }
}
 
int zerocount(int j)   //подсчет нулей в j-ом столбце
{
    int count = 0;
    for (int i = 0; i < nMax; i++)
      {
          if (a[i][j] == 0) count++;
      }
    return count;
}
 
bool f1()               //проверка на возрастание количества нулей
{
    bool stop = true;
    for (int i=0; i<nMax-1; i++)
      {
          if (a[nMax][i] < a[nMax][i+1]) continue;
          else
          {
              stop = false;
              break;
          }
//          if (a[nMax][i] >= a[nMax][i+1])
//            {
//                stop = false;
//                break;
//            }
      }
    return stop;
}
з.ы. функция fill_array, закоментирована в main и временно не используется, значения массиву присваиваются вручную.
з.з.ы. количество нулей записывается в последнюю строку матрицы, она специально для этого заведена. следовательно функция f1 работает как раз с этой строкой
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2012, 06:57     Матрица
Посмотрите здесь:

матрица C++
матрица C++
C++ матрица
C++ Матрица
C++ Матрица
С++ матрица C++
C++ матрица...
C++ матрица

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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