Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
1

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

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

Author24 — интернет-сервис помощи студентам
минимум среди сумм модулей элементов диагоналей, параллельных побочной диагонали матрицы.
Я ввожу матрицу 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;
 
}
заранее спасибо!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.04.2012, 19:45
Ответы с готовыми решениями:

Найти слова, повторяющиеся более одного раза, не могу найти ошибку
#include &lt;iostream&gt; using namespace std; void obr1(char **s, char **mas, int n, int m) { int...

Массивы. Посчитать количество положительных, найти минимальное, удалить строку с минимальным (Не могу найти ошибку)
// Заданы матрицы X(8;4),Y(5;5),Z(6;9). // Для каждой из матриц определить строку, в которой...

Не могу найти ошибку
Как правильно сделать через рекурсию?

Не могу найти ошибку
Доброго времени суток, вообщем такое задание: В одномерном массиве,состоящем из n вещественных...

6
4 / 4 / 2
Регистрация: 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;
 
}
Ты ведь даже не компилировал, я прав?
0
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...
0
4 / 4 / 2
Регистрация: 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;
}
Щас вроде все норм
0
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...?
0
4 / 4 / 2
Регистрация: 27.03.2012
Сообщений: 13
17.04.2012, 23:50 6
sum += abs(m[i][z]);
минимум среди сумм модулей элементов диагоналей
0
1 / 1 / 0
Регистрация: 11.11.2011
Сообщений: 49
18.04.2012, 07:52  [ТС] 7
я потом уже допер, спасибо, тупонул)
0
18.04.2012, 07:52
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.04.2012, 07:52
Помогаю со студенческими работами здесь

Не могу найти ошибку
В тексте слова которые разделены точками, заменить на символы «ТЧК» и подсчитать количество замен....

Не могу найти ошибку
Не могу найти ошибку 1. Минимальный по модулю элемент массива. 2. Сумму модулей элементов...

Не могу найти ошибку
#include &lt;iostream&gt; #include &lt;cmath&gt; #define N = 3 using namespace std; void vvodMatr(int a,...

Не могу найти ошибку
Задача: вывести элементы массива, которые повторяются ровно 2 раза #include &lt;cstdlib&gt; #include...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru