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

Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов) - C++

Восстановить пароль Регистрация
 
20skorpion10
Сообщений: n/a
16.03.2013, 18:13     Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов) #1
Среди столбцов заданной целочисленной матрицы, которые включают только такие элементы, которые по модулю не больше 10, найти столбец с минимальной суммой элементов.


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
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <stdlib.h>
#include <time.h>
 
using namespace std;
 
int main()
{
    const int N = 10;
    srand(time(NULL));
    int mas[N][N]={0};
    int result[N]={0};
    int i, j, k; 
     for(i = 0; i < N; i++)
     {
         for(j = 0; j < N; j++)
         {
             mas[i][j] = rand()%10;
             cout << mas[i][j] << " ";
             }
             cout << endl;
}
    for(int j = 0; j < N; j++)
    {
            int sum = 0;
            for(int i = 0; i < N; i++);
            {
                  sum = sum+mas[i][j];
                  }
             result[j] = sum;      
            }
    for(j = 0; j < N; j++);
    {
          int min = 99999;
          if(result[j] < min)
          result[j] = min;
          }    
          cout << min << endl;
getch();
return 0;
    }
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.03.2013, 18:13     Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов)
Посмотрите здесь:

C++ В двумерном N*K массиве целых чисел поменять строку с максимальной суммой элементов со строкой с минимальной суммой элементов.
Найти строку с минимальной суммой элементов C++
Дан двумерный массив. Найти строку с минимальной суммой элементов C++
C++ Заменить все столбцы на столбец с минимальной суммой элементов (Класс)
C++ Массив: Найти столбик с минимальной суммой элементов
В заданной матрице найти номера всех столбцов с минимальной суммой элементов C++
В целочисленной матрице найти номер столбца с минимальной суммой элементов C++
Дана Матрица Н(6,5). Найти столбец с минимальной суммой элементов C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
AlexAsche
 Аватар для AlexAsche
77 / 77 / 5
Регистрация: 27.01.2013
Сообщений: 323
16.03.2013, 19:21     Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов) #2
C++
1
2
if(result[j] < min)
          result[j] = min;
Наоборот min = result[j];

Добавлено через 6 минут
и int min должен быть объявлен раньше for

C++
1
2
3
4
5
6
int min = 99999;
for(j = 0; j < N; j++);
    {
          if(result[j] < min)
                min = result[j];
     }
Добавлено через 26 минут
так а зачем for(i = 0; i < N; i++) с ; ?

и int i,j; в начале c for(int i = 0; i < N; i++) что-то одно.

Хотя бы так:

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
const int N = 10;
    int i,j;
    srand(time(NULL));
    int mas[N][N]={0};
    int result[N]={0};
    for(i = 0; i < N; i++)
    {
        for(j = 0; j < N; j++)
        {
            mas[i][j] = rand()%10;
            cout << mas[i][j] << " ";
        }
        cout << endl;
    }
    for(j = 0; j < N; j++)
    {
        int sum = 0;
        for(i = 0; i < N; i++)
        {
            sum = sum+mas[i][j];
        }
        result[j] = sum;
    }
    int min = 99999;
    for(j = 0; j < N; j++)
    {   
        if (result[j] < min)
            min = result[j];
    }
    cout << min << endl;
    getch();
 
    return 0;
Ev[G]eN
Эксперт С++
 Аватар для Ev[G]eN
5093 / 1531 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
16.03.2013, 21:07     Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов) #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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
 
int main ()
{
    srand(time(0));
    const int matrixSize = 5;
    int matrix[matrixSize][matrixSize];
 
    int limitValue = 10;
    std::cout << "Matrix: " << std::endl;
    for (int i = 0; i < matrixSize; i++) {
        for (int j = 0; j < matrixSize; j++)
            std::cout << std::setw(5) << (matrix[i][j] = rand() % (limitValue + 1));
        std::cout << std::endl;
    }
 
    int colNumber = 0;
    int minimalSum = matrixSize * limitValue;
    for (int j = 0; j < matrixSize; j++) {
        int currSum = 0;
        for (int i = 0; i < matrixSize; i++)
            currSum += matrix[i][j];
        if (currSum < minimalSum) {
            minimalSum = currSum;
            colNumber = j;
        }
    }
    std::cout << "Col with minimal sum (" << minimalSum << "): " << (colNumber + 1) << std::endl;
 
    return 0;
}
Цитата Сообщение от AlexAsche Посмотреть сообщение
C++
1
2
3
4
5
6
7
int min = 99999;
for(j = 0; j < N; j++)
{ 
    if (result[j] < min)
    min = result[j];
}
cout << min << endl;
если уж работаете с дополнительным массивом, то гораздо рациональней изначально минимальному присвоить значение первого элемента.
Yandex
Объявления
16.03.2013, 21:07     Подскажите, пожалуйста, почему не работает? (найти столбец с минимальной суммой элементов)
Ответ Создать тему
Опции темы

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