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

Двумерный массив. Сумма элементов диагоналей - C++

Восстановить пароль Регистрация
 
Deadly
0 / 0 / 0
Регистрация: 14.10.2013
Сообщений: 11
02.12.2013, 19:51     Двумерный массив. Сумма элементов диагоналей #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
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
#include "stdafx.h"
#include "iostream"
#include "conio.h"
#include "iomanip"
using namespace std;
const int size=3;
int main()
{
setlocale(LC_ALL,"Rus");\
 
int MatrixItem [size][size];
 
for (int i=0; i<size; i++)
{
 for (int j=0; j<size; j++)
     {
     cout << " items:[" << i << "][" << j << "] = ";
     cin >> MatrixItem[i][j];
     }
}
 
 
cout << "matrix:" <<endl;
    for (int i=0; i<size; i++)
    {
         for (int j=0; j<size; j++)
        {
         cout << setw(5) << MatrixItem[i][j];
        }
         cout << endl;
    }
 
 
int count; 
bool truth;
 
for (int j=0; j<size; j++)
{
    truth=true;
    count=0;
    for (int i=0; i<size; i++)
    {
        count=count+MatrixItem[i][j];
        if (MatrixItem[i][j] < 0) 
        {
            truth=false;
        }
    }
    if (truth == true) cout << "Сумма ["<<j<<"] -го столбца = "<< count << endl;
    if (truth == false) cout << "["<<j<<"]"<< " -й столбец имеет отрицательный элемент." << endl;
}
 
int countminimal = 32767, k=size-1;
count=0;
for(int l=0; l<2*size-2; l++)
{
    for(int i=0; i<size; i++)
    {
        for(int j=0; j<size; j++)
        {
            if (j==(size-i-1) - k)
            {
                count=count+abs(MatrixItem[i][j]);
            }
        }
    }
 if (l!=size) 
 {
    if (count < countminimal)
    {
        countminimal=count;
        k--;
        cout << "Сумма модулей диагонали ["<<l<<"] = "<<count<<endl;
        count=0;
    }
 }
}
cout << " Минимальная сумма = "<<countminimal<<endl;
system("PAUSE");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.12.2013, 19:51     Двумерный массив. Сумма элементов диагоналей
Посмотрите здесь:

C++ Сформировать одномерный массив, элементами которого являются средние арифметические значения элементов главной и побочной диагоналей
C++ Двумерный массив (Определить: сумму элементов в тех строках, которые не содержат отрицательных элементов)
Двумерный массив и сумма элементов C++
C++ Динамический массив: вычислить сумму элементов главной и побочной диагоналей (Исправление кода)
C++ Дано двумерный массив целых чисел. Найти номер строки, в которой сумма отрицательных нечетных элементов наибольшая
Сформировать одномерный массив, элементы которого равны произведениям индексов последних отрицательных элементов диагоналей C++
C++ Двумерный массив, сумма столбца
C++ Двумерный массив, сумма строки
C++ Двумерный массив. Неправильно считается сумма. Как исправить?
C++ Двумерный массив: сумма строк, максимумы столбцов
Построить массив совпадений элементов диагоналей матрицы C++
C++ Получить одномерный массив, хранящий произведение элементов восходящих диагоналей матрицы

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

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

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