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

Матрица - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дан текстовый файл. Определить среднее количество слов в строке http://www.cyberforum.ru/cpp-beginners/thread577334.html
Дан текстовый файл. Определить среднее количество слов в строке.
C++ Задача на обработку файла Записать в файл n натуральных чисел. получить в другом файле все компоненты файла f, кроме тех, которые кратны k. Вывести полученный файл на печать. http://www.cyberforum.ru/cpp-beginners/thread577333.html
Как сделать так, чтобы условие начало работать?Подскажите,пожалуйста C++
Здравствуйте. Прошу,подскажите,пожалуйста, ступор уже. Вот прога: for(n=1;n<=100;n++) do { P0=1/(exp(r,n)); Temp=power(r,n)/factorial(n); P_otk=Temp*P0; Q=1-P_otk;
Строки на С++ C++
Мне надо перекопировать все символы с одного текстового файла в другой В общем проблема такая: в результирующем тексте(result.txt) вместо латиницы выводится абракадабра. В чем ошибка?? #include <stdio.h> #include <conio.h> #include <string.h> #include <locale.h> void main ()
C++ Обработка исключений в Borland C++ 3.0 http://www.cyberforum.ru/cpp-beginners/thread577303.html
Все привет. Готовясь к Госу, я вспомнил что в УЗе, мы когда-то проходили С++, сел пробывать делать элементарные задачки, все вроде как да получалось, пока мне не взбрело в голову отлавливать исключения. После года программирования на C#, начал лепить try - catch (выделились белым - сначала удивился (тип как зарезервированные слова или как правильнее?), потом понял, что не прокатит + гугл...
C++ Работа с приоритетной очередью Здравствуйте уважаемые форумчане. Нужно написать программу работы с приоритетной очередью. Вот собственно задание: "Есть 2 очереди, организованные на массивах и списках. Вторая очередь приоритетная. Постановление процессов в очередь выполняется подряд в начало второй очереди, процесс сразу начинает исполнятся. После прерывания, процесс становится в первую очередь. Исполнение LIFO." Вот кое... подробнее

Показать сообщение отдельно
[WRG]
50 / 50 / 9
Регистрация: 20.11.2011
Сообщений: 243
Записей в блоге: 1

Матрица - C++

17.05.2012, 06:57. Просмотров 217. Ответов 0
Метки (Все метки)

если в матрице количество нулей в столбиках возрастает, то нужно подсчитать общее количество нулей в матрице. если же наоборот, то надо найти столбик с максимальным количеством нулей.

проблема в функции 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 работает как раз с этой строкой
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru