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

Прокомментировать код с матрицей

09.01.2013, 18:25. Показов 619. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите. Может кто популярно объяснить, как работает данная вещь:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
{int s=0,s1,s2;  
    s=arr[0][n-1];
    for(i=1; i<n; i++)
    {
        s1=s2=0;
        for(j=0; j<n-i; j++)
        {
            s1+=arr[i+j][j];
            s2+=arr[j][i+j];
        }
        if(s1<s) s=s1;
        if(s2<s) s=s2;
    }
Вот сама программа:
Кликните здесь для просмотра всего текста
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
#include "stdafx.h"
#include "locale.h"
#include "stdio.h"
#include "conio.h"
#include "stdlib.h"
#include "time.h"
#include <iostream>
 
int _tmain(int argc, _TCHAR* argv[])
{setlocale(0, "Russian");
    
    int **arr=0,n, i, j, flag, x, sum=0;
    printf("\n Введите размерность матрицы А: ");
    scanf("%d", &n);
//Объявление динамического массива
    arr = new int* [n];
    for(i=0;i<n;i++)
        arr[i] = new int [n];
 
    printf("\n Выберите способ ввода матрицы: 1 - случайные значения, 2 - ручной ввод  ");
    scanf("%d", &flag);
    if(flag == 1){
        srand(time(0));
        for(i = 0; i <n; i++){
            for(j = 0; j < n; j++)
                arr[i][j]=(-5000+rand()%13001)/1000;
        }
    }
    else if(flag == 2){
            for(i = 0; i < n; i++){
                for(j = 0; j < n; j++){
                    printf("A[%d][%d] = ", i, j);
                    scanf("%d", &arr[i][j]);
                }
                printf("\n");
            }
    }
    printf("\n Исходная матрица А: \n\n");
    for(i = 0; i < n; i++){
        for(j = 0; j < n; j++)
            printf("%3d", arr[i][j]);
        printf("\n\n");
    }
    for(i=0;i<n;i++)
    {
        x=true;
         for(j=0;j<n;j++)
         if (arr[i][j]<0) 
             x=false;
         if (x==true) 
            {sum=0;
             for(j=0;j<n;j++)
                 sum+=arr[i][j];{
         printf("Сумма элементов в строкe %d,не содержащей отрицательных значений = %d\n",i,sum);
             }}
    }
    {int s=0,s1,s2;  
    s=arr[0][n-1];
    for(i=1; i<n; i++)
    {
        s1=s2=0;
        for(j=0; j<n-i; j++)
        {
            s1+=arr[i+j][j];
            s2+=arr[j][i+j];
        }
        if(s1<s) s=s1;
        if(s2<s) s=s2;
    }
    printf("Минимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы=%d\n",s);
    getch();
    for(i=0;i<n;i++)
        delete [] arr[i];
    delete [] arr;
    return 0;
    }}

Заранее спасибо!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.01.2013, 18:25
Ответы с готовыми решениями:

Прокомментировать код
Код писал не я, мне бы разобраться что значит та или иная строка. Буду очень благодарен если вы напишите комментарии к основным строчкам. ...

Прокомментировать код
#include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #include &lt;iostream.h&gt; #include &lt;string.h&gt; #include &lt;math.h&gt; main() ...

Прокомментировать код
#include &quot;stdafx.h&quot; #include&lt;iostream&gt; #include&lt;math.h&gt; #include &lt;stdlib.h&gt; using namespace std; int main() { double eps,...

3
 Аватар для m1Rr0r
250 / 232 / 46
Регистрация: 05.02.2010
Сообщений: 3,288
09.01.2013, 19:11
Кликните здесь для просмотра всего текста
Создается матрица заданного размера.
Заполняется вручную или рандомными значениями.
Печатается на экран.
Подсчитывается сумма элементов в строке при условии что в строке не будет отрицательных элементов.
Вычисляется минимум среди сумм элементов диагоналей параллельных главной диагонали.
Очищается динамическая память ранее выделенная под матрицу
0
0 / 0 / 0
Регистрация: 03.01.2013
Сообщений: 32
09.01.2013, 23:26  [ТС]
Спасибо конечно, но меня интересует каким образом производиться вычисление сумм диагоналей параллельных главной
. Сам понимаю, но как объяснить преподавателю? Меня интересует именно это место:
C++
1
2
            s1+=arr[i+j][j];
            s2+=arr[j][i+j];
0
 Аватар для David Sylva
1321 / 983 / 267
Регистрация: 17.05.2012
Сообщений: 2,687
10.01.2013, 14:49
Цитата Сообщение от Serdox Посмотреть сообщение
s1+=arr[i+j][j];
* * * * * * s2+=arr[j][i+j];
это аналогично s1 = s1 + arr[i+j][j];
s2 = s2 + arr[j][i+j];
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.01.2013, 14:49
Помогаю со студенческими работами здесь

Прокомментировать код
Добрый вечер! Есть вопросы по коду... не понимаю некоторые строки. Их выделю розовым цветом. Буду очень благодарна!!! #include...

Прокомментировать код
Нужна помощь. Необходимо поставить комментарии к каждой строке программы. #include &quot;stdafx.h&quot; #include...

Прокомментировать код
помогите понять этот код int main(){ const int PASSWORD_LENGTH=10; const char *...

Прокомментировать код
нужно описать что делают строки готовой программы #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;cmath&gt; using namespace...

Прокомментировать код
Прокомментировать код #include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #define n 5 int main() { int...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 25.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 25.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Номеклатура. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru