Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.65/40: Рейтинг темы: голосов - 40, средняя оценка - 4.65
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26

Вычислить сумму элементов матрицы, расположенных на главной диагонали и выше нее

31.12.2013, 19:41. Показов 8158. Ответов 40
Метки нет (Все метки)

Дано задание:

Дана действительная квадратная матрица порядка 7. Вычислить сумму
тех её элементов, расположенных на главной диагонали и выше нее, которые превосходят
по величине все элементы, расположенные ниже главной диагонали. Заменить этой
суммой элемент на главной диагонали соответствующего столбца. Если на главной
диагонали и выше нее нет элементов с указанным свойством, то элемент на главной
диагонали оставить без изменения. Элементы главной диагонали (неизмененные) вывести
в массив. Вывести исходную и преобразованную матрицы, полученный массив.


Подскажите пожалуйста механизм поиска элементов расположенных на главной диагонали и выше нее, которые превосходят по величине все элементы, расположенные ниже главной диагонали и нахождения их суммы...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
#include <iostream.h>
#include <stdlib.h>
#include <time.h>
main(){
       setlocale(LC_ALL,"RUS");
       int a[7][7], i,j,max=0;
       srand (time(NULL));
       for (i=0; i<7; i++)
       for (j=0; j<7; j++){
           a[i][j] = rand()%10;
           }
           cout<<"матрица А"<<endl<<endl;
           for (i=0; i<7; i++){
       for (j=0; j<7; j++)
           cout<<a[i][j]<<"  ";cout<<endl;
           } 
           for (i=0; i<7; i++){
       for (j=0; j<7; j++)
       if (i>j){
                if (a[i][j]>max) max = a[i][j];}}
                
                 for (i=0; i<7; i++){
       for (j=0; j<7; j++)
       if (i<=j){
                 if(a[i][j]>max){
                                 if(i==j)                
                 a[i][j]=a[i][j]+a[i][j];}}
       cout<<endl<<endl;
       for (i=0; i<7; i++){
       for (j=0; j<7; j++)
       cout<< a[i][j]<<"  ";
       cout<<endl;}
       }
       system ("pause");
       return 0;}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.12.2013, 19:41
Ответы с готовыми решениями:

Вычислить сумму элементов матрицы, расположенных выше главной диагонали
выдает ошибки: Ошибка 1 error LNK2001: неразрешенный внешний символ &quot;_mainCRTStartup&quot; Ошибка 2 error LNK1120: 1 неразрешенных внешних...

Вычислить сумму элементов расположенных ниже главной диагонали, но выше побочной диагонали
Дана целочисленная квадратная матрица размера NxN. Вычислить сумму элементов расположенных ниже главной диагонали, но выше побочной...

Найти сумму элементов матрицы, расположенных выше главной диагонали и ниже побочной диагонали
не соображу В среде MS Visual C++ разработать программу, которая формирует матрицу размером n х n (значение n вводится с клавиатуры) и...

40
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
31.12.2013, 22:19
Скопируйте то,что внутри main в вашу старую программу и запустите.
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 22:31  [ТС]
В принципе правильно, но через раз как-то) Спасибо еще раз огромное.
0
Заблокирован
31.12.2013, 22:34
нет, надо понять почему иногда работает неправильно. Надо перепроверить границы циклов, скорее всего ошибка в них.

Все таки скопируйте ошибочный вариант, в консоли правой кнопкой мыши: Выделить все ->Enter и вставляйте сюда.

Добавлено через 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
47
48
49
50
51
52
53
 
       setlocale(LC_ALL,"RUS");
       int a[7][7],mas[7], i,j,temp;
       srand (time(NULL));
       for (i=0; i<7; i++)
       for (j=0; j<7; j++)
       {
           a[i][j] = rand()%10;
       }
       cout<<"матрица А"<<endl<<endl;
       for (i=0; i<7; i++)
       {
       mas[i]=0;
       for (j=0; j<7; j++)
       cout<<a[i][j]<<"  ";cout<<endl;
       } 
 
       for (i=0; i<7; i++)
       {
            for (j=i+1; j<7; j++)
            if (a[j][i]>mas[i])
            {
             mas[i]=a[j][i];
            }
       }
            cout<<endl;
           for(int j=0;j<7;j++)
           cout<<mas[j]<<" ";
           cout<<endl<<endl;
        for (i=0; i<6; i++)
       {
            temp=a[i][i];
            a[i][i]=0;
            for (j=0; j<i; j++)
            {
                if (a[j][i]>mas[i])
                {
                a[i][i]=a[i][i]+a[j][i];
                }
            }
            if(a[i][i]==0)a[i][i]=temp;
 
       }
       cout<<endl<<endl;
       for (i=0; i<7; i++)
       {
       for (j=0; j<7; j++)
       cout<< a[i][j]<<"  ";
       cout<<endl;
       }
      
       system ("pause");
       return 0;
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 22:45  [ТС]
не могу скопировать....действие недоступно..
0
Заблокирован
31.12.2013, 22:46
эм, ну может все же перенаберете?
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 22:47  [ТС]
Microsoft Windows [Version 6.1.7601]
(c) Корпорация Майкрософт (Microsoft Corp.), 2009. Все права защищены.

D:\>12332.exe
матрица А

8 9 9 6 7 0 4
4 8 9 5 3 5 1
6 6 1 6 5 0 0
4 6 8 8 1 1 4
1 0 0 3 8 7 4
0 9 0 7 1 4 7
6 9 1 6 5 5 5


8 9 9 6 7 0 4
4 8 9 5 3 5 1
6 6 18 6 5 0 0
4 6 8 8 1 1 4
1 0 0 3 7 7 4
0 9 0 7 1 7 7
6 9 1 6 5 5 5
Для продолжения нажмите любую клавишу . . .
0
Заблокирован
31.12.2013, 22:49
ilmat, а что тут неправильного?
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 22:51  [ТС]
5-й столбец
0
Заблокирован
31.12.2013, 22:53
и все же не вижу ошибки.
mas[4]=5;
А сумма элементов больше 5, выше главной диагонали = 7.
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 23:01  [ТС]
в пятом столбце элементом ГД является 8. 8>1>5 также семерка, стоящая выше>1>5....на место восьмерки по идее должно встать 15...а в целом, как я и говорил всё правильно.
0
Заблокирован
31.12.2013, 23:03
то есть вам нужно к сумме добавить и элемент на главной диагонали?
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 23:05  [ТС]
или я не сказал, что элемент ГД, если он больше, тоже плюсуется?

Добавлено через 40 секунд
0
Заблокирован
31.12.2013, 23:07
сделайте вот так:
C++
1
// a[i][i]=0;
то есть эту строчку можно совсем убрать

Добавлено через 40 секунд
Цитата Сообщение от ilmat Посмотреть сообщение
или я не сказал, что элемент ГД, если он больше, тоже плюсуется?
похоже, что я невнимательно прочел задание
0
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 23:09  [ТС]
А не получится так, что элемент ГД будет прибавляться в любом случае? Ведь нужно, чтобы он был тоже больше нижних...
0
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
31.12.2013, 23:10
Цитата Сообщение от ilmat Посмотреть сообщение
или я не сказал, что элемент ГД, если он больше, тоже плюсуется?
Вы написали,я не обратил внимание

Измените простое зануление,на условное:
if(a[i][i]<=mas[i])
{
a[i][i]=0;
}
2
Заблокирован
31.12.2013, 23:12
Цитата Сообщение от ilmat Посмотреть сообщение
А не получится так, что элемент ГД будет прибавляться в любом случае? Ведь нужно, чтобы он был тоже больше нижних...
верно, надо добавить условие, по поводу зануления, в случае, если он меньше

Добавлено через 1 минуту
меня опередили
1
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 23:15  [ТС]
У меня просто скилла не хватает такие цепочки мелочей продумывать(
0
31.12.2013, 23:16

Не по теме:

я думаю ни у кого все мелкие вопросы сразу не решаются, а уже в ходе проверки их обнаруживают и быстро правят.
Хотя я не программист, может ошибаюсь :)

1
1 / 1 / 0
Регистрация: 31.12.2013
Сообщений: 26
31.12.2013, 23:22  [ТС]
Всё..сейчас идеально) Благодарствую раз еще)
0
Заблокирован
31.12.2013, 23:24
)С Наступающим!
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.12.2013, 23:24

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

Найти сумму модулей элементов, расположенных выше главной диагонали матрицы
for( int i = 0; i &lt; n; i++ ) for( int j = i+1; j &lt; n; j++ ) s += abs(array); Так он находит сумму модулей элементов ниже главной...

Квадратная матрица: Вычислить сумму элементов, расположенных на главной диагонали и выше, которые превосходят все элементы
Помогите, пожалуйста, решить это задание! Плохо понимаю, как работать с массивами в C++ Дана действительная квадратная матрица порядка...

Вычислить сумму элементов матрицы выше главной диагонали
Здравствуйте. Помогите решить задание. Нужно вычислить сумму элементов матрицы выше главной диагонали. Заранее спасибо.

Вычислить сумму элементов выше главной диагонали матрицы
ввести двумерный массив b . вычислить сумму элементов лежать выше главной диагонали матрицы и отобразить на экране. p. s помогите...


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

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Новые блоги и статьи
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru