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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
123456кам
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
#1

Не могу найти ошибку... - C++

16.04.2012, 19:45. Просмотров 294. Ответов 6
Метки нет (Все метки)

минимум среди сумм модулей элементов диагоналей, параллельных побочной диагонали матрицы.
Я ввожу матрицу 1 2 3 4 5 6 7 8 9, т.е. минимум сумм элементов диагоналей параллельных побочной будет 1. Вроде так.

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
#include "stdafx.h"
#include <iostream.h>
#include <math.h>
 
void main(void)
{
    int const n = 3;
    int m[n][n];
    cout << "Vvedite matrizy:" << endl;
    for(int i = 0; i < n; i++)
        for(int j = 0; j < n; j++)
        {
            cout << "Vvedite element [" << i+1 << "][" << j+1 << "]:";
            cin >> m[i][j];
        }
 
        int sum, min, z;
 
            for(int j = n-1; j > 0; j--)
            {
                sum = 0;
                i = n-1;
                for(z = j; z < n; z++) i--;
                sum += abs(m[i][z]);
                if ( j == n-1)
                min = sum;
                else if (sum < min)
                min = sum;
            }
 
        for(j = n-2; j >= 0; j--)
        {
            sum = 0;
            i = 0;
            for(z = j; z > 0; z--) i++;
            sum += abs(m[i][z]);
            if(j == n-2)
                min = sum;
            else if(sum < min)
                min = sum;
        }
 
 
            cout << "Minimum Sum = " << min << endl;
 
}
заранее спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.04.2012, 19:45     Не могу найти ошибку...
Посмотрите здесь:

C++ Не могу найти ошибку
C++ Не могу найти ошибку!
Не могу найти ошибку! C++
Не могу найти ошибку C++
Не могу найти ошибку C++
C++ Не могу найти ошибку
Не могу найти ошибку C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
rush2331
4 / 4 / 0
Регистрация: 27.03.2012
Сообщений: 13
16.04.2012, 19:58     Не могу найти ошибку... #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
#include <iostream>
#include <math.h>
 
using namespace std;
 
void main(void)
{
int const n = 3;
int m[n][n];
cout << "Vvedite matrizy:" << endl;
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++)
{
cout << "Vvedite element [" << i+1 << "][" << j+1 << "]:";
cin >> m[i][j];
}
 
int sum, min, z;
 
for(int j = n-1; j > 0; j--)
{
sum = 0;
int i = n-1;
for(z = j; z < n; z++) i--;
sum += abs(m[i][z]);
if ( j == n-1)
min = sum;
else if (sum < min)
min = sum;
}
 
for(int j = n-2; j >= 0; j--)
{
sum = 0;
int i = 0;
for(z = j; z > 0; z--) i++;
sum += abs(m[i][z]);
if(j == n-2)
min = sum;
else if(sum < min)
min = sum;
}
 
 
cout << "Minimum Sum = " << min << endl;
 
}
Ты ведь даже не компилировал, я прав?
123456кам
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
16.04.2012, 20:51  [ТС]     Не могу найти ошибку... #3
да я исправлял, исправлял... ничего не получалось вот и кинул, да, видно забыл откомпилировать... спасибо за помощь!

Добавлено через 4 минуты
Я наверное что-то не так пойму, а почему при вводе матрицы 9 8 7 6 5 4 3 2 1 выдает ответ 6... хотя ведь тоже должен 1...
rush2331
4 / 4 / 0
Регистрация: 27.03.2012
Сообщений: 13
16.04.2012, 21:32     Не могу найти ошибку... #4
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
#include <iostream>
#include <math.h>
 
using namespace std;
 
void main(void)
{
int const n = 3;
int m[n][n];
cout << "Vvedite matrizy:" << endl;
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++)
{
cout << "Vvedite element [" << i+1 << "][" << j+1 << "]:";
cin >> m[i][j];
}
 
int sum, min, min2, z;
 
for(int j = n-1; j > 0; j--)
{
sum = 0;
int i = n-1;
for(z = j; z < n; z++, i--)
sum += abs(m[i][z]);
if ( j == n-1)
min = sum;
if (sum < min)
min = sum;
}
 
for(int j = n-2; j >= 0; j--)
{
sum = 0;
int i = 0;
for(z = j; z >= 0; z--, i++)
sum += abs(m[i][z]);
if(j == n-2)
min2 = sum;
if(sum < min2)
min2 = sum;
}
 
if (min < min2)
cout << "Minimum Sum = " << min << endl;
else
cout << "Minimum Sum = " << min2 << endl;
}
Щас вроде все норм
123456кам
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
17.04.2012, 14:14  [ТС]     Не могу найти ошибку... #5
Вот, я тоже что в конце нужно условие, но не начинал пока в первой части не разобрался... спасибо большое!

Добавлено через 15 часов 58 минут
подскажи еще одно, почему когда ввожу матрицу -1 2 3 4 5 6 7 8 9 выдает минимум 1, а не -1...?
rush2331
4 / 4 / 0
Регистрация: 27.03.2012
Сообщений: 13
17.04.2012, 23:50     Не могу найти ошибку... #6
sum += abs(m[i][z]);
минимум среди сумм модулей элементов диагоналей
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.04.2012, 07:52     Не могу найти ошибку...
Еще ссылки по теме:

Не могу найти ошибку C++
Не могу найти ошибку C++
Не могу найти ошибку C++
Не могу найти ошибку C++
C++ Не могу найти ошибку!

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

Или воспользуйтесь поиском по форуму:
123456кам
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
18.04.2012, 07:52  [ТС]     Не могу найти ошибку... #7
я потом уже допер, спасибо, тупонул)
Yandex
Объявления
18.04.2012, 07:52     Не могу найти ошибку...
Ответ Создать тему
Опции темы

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