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

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

Войти
Регистрация
Восстановить пароль
 
WOLF666
0 / 0 / 0
Регистрация: 14.05.2011
Сообщений: 29
#1

Сумма паралельных диагоналей. - C++

14.05.2011, 18:09. Просмотров 317. Ответов 2
Метки нет (Все метки)

Задача: Найти сумму всех диагоналей параллельных главной матрицы n*n. Вывести массив из сумм на экран, найти максимум нового массива.
Написал код, но он не работает, не пойму почему. Подскажите в чем проблема!
Спасибо за внимание!)
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
#include <conio.h>
#include <iostream>
using namespace std;
int main()
{
    int n,i,j,v,nuz,sumd,k,l=0,p,sum[50];
    cout<<"Vvedit rozmir";
    cin>>n;
    int** a;
    a=new int* [n]; 
    for(i=0;i<n;i++)
        a[i]=new int [n]; 
    for( i=0;i<n;i++){
        for(j=0;j<n;j++)
            a[i][j]=rand()%10-1;}
                cout << endl;
    for(i=0;i<n;i++){
        for(j=0;j<n;j++)
        cout<< a[i][j]<< "  ";
            cout << endl;}
    /*Знаходимо суми рівнобіжних діагоналей*/
    v=n-1;
    nuz=n-1;
    p=0;
    k=0;
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            if (i==0 && j!=0)
            {
                sumd=0;
                l=j;
                for (k=0;k=v;k++)
                {
                    sumd+=a[k][l];
                    l++;
                }
                sum[p]=sumd;
                v--;
                p++;
            }
            if (j==0 && i!=0)
            {
                sumd=0;
                l=i;
                for (k=0;k=nuz;k++)
                {
                    sumd+=a[l][k];
                    l++;
                }
                sum[p]=sumd;
                nuz--;
                p++;
            }           
        }
    }
    for (i=0;i=p;i++)
        cout << sum[i] <<"="<<"     ";
    getch();
}
Добавлено через 4 минуты
Если что-то не понятно в коде, то пишите в скайп Besecnuy. Так будет быстрее, а то мне нужно на сессию сдать. помогите чем сможете.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.05.2011, 18:09
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Сумма паралельных диагоналей. (C++):

сумма диагоналей??? - C++
Вот в чем вопрос! Вроде все правильно, но сумму неправильно вычисляет, а именно нужно: Найти максимальную, из всех сумм диагоналей,...

Сумма диагоналей матрицы - C++
как найти сумму элементов каждой диагонали матрицы, параллельной побочной?

сумма диагоналей паралельно главной - C++
задание, нужно получить и вывести на экран суммы диагоналей находящейся над и под главной диагонали то есть паралельные главной диагонали....

Упорядочить блоки по величине их диагоналей (по убыванию значений их диагоналей). - C++
Итак, есть следующая задача: В заданной двумерной матрице выделить 3 блока по 2 строки и 2 столбца (блоки расположены на главной...

Напечатать элементы массива в виде двух паралельных столбцов - C++
В одномерном массиве размещены: в первых элементах значение аргумента, в следующих-соответствующие им значение функции. Напечатать элементы...

Определить максимум матрицы среди сумм диоганалей паралельных главной - C++
помогите пожалуйста мне нужно написать программу на си : дана целочисленная квадратная матрица 1)определить произведение элементов в...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
14.05.2011, 19:20 #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
#include <conio.h>
#include <iostream>
using namespace std;
int main()
{
        int n,i,j,sumd,l=0,p,sum[50], max=-1;
        cout<<"Vvedit rozmir";
        cin>>n;
        int** a;
        a=new int* [n]; 
        for(i=0;i<n;i++)
                a[i]=new int [n]; 
        for( i=0;i<n;i++){
                for(j=0;j<n;j++)
                        a[i][j]=rand()%10-1;}
                                cout << endl;
        for(i=0;i<n;i++){
                for(j=0;j<n;j++)
                cout<< a[i][j]<< "  ";
                        cout << endl;}
        /*Знаходимо суми рівнобіжних діагоналей*/
        p=2*n-2;
        for(i=1;i<n;i++)
        {
            sumd=0;
            for(j=0; j+i<n; j++)
                sumd+=a[j][i+j];
            if(max==-1)
                max=l;
            else
            {
                if(sum[max]<sumd)
                    max=l;
            }
            sum[l++]=sumd;                
        }
        for(i=1;i<n;i++)
        {
            sumd=0;
            for(j=0; j+i<n; j++)
                sumd+=a[i+j][j];
            if(sum[max]<sumd)
                max=l;
            sum[l++]=sumd;
        }
        for (i=0;i<p;i++)
                cout <<i <<"="<<sum[i]<<endl;
        cout<<"Max sum: "<<sum[max]<<endl;
        getch();
        return 0;
}
WOLF666
0 / 0 / 0
Регистрация: 14.05.2011
Сообщений: 29
15.05.2011, 01:05  [ТС] #3
Спасибо огромное!)))
Буду теперь разбираться с кодом))))
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.05.2011, 01:05
Привет! Вот еще темы с ответами:

Составить программу, в которой вычислить z=(s1+s2)/(k1*k2), где s1 и k1 - сумма и количество положительных элементов массива Х[N]; s1 u k2 - сумма - C++
Составить программу, в которой вычислить z=(s1+s2)/(k1*k2), где s1 и k1 - сумма и количество положительных элементов массива Х; s1 u k2 ...

Перестановка диагоналей в матрице - C++
Нужно переставить диагонали в матрице, сори если было не нашел: Вот тут написал уже кое-что: #include &lt;iostream&gt; #include &lt;cstdlib&gt; ...

Сортировка диагоналей в массиве - C++
Прога крашиться, и не могу понять почему. Надо отсортировать гл. диагональ в массиве и параллельные ей по-отдельности. #include...

Сортировка диагоналей двумерного массива - C++
Здравствуйте. Помогите решить вот такую задачу: Заранее спасибо.


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

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