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

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

Войти
Регистрация
Восстановить пароль
 
techies
Сообщений: n/a
#1

Найти максимум среди сумм элементов диагоналей, параллельных главной - C++

05.09.2014, 19:30. Просмотров 580. Ответов 2
Метки нет (Все метки)

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

Вот программа:

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 <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <iostream>
//#include "stdafx.h"
using namespace std;
 
int main()
{    
   const int n = 3;
   int i,j,sum=0,v=0,maxsum=0;   
        int a[n][n],s[2*n];
        printf ("Kak vvodit' elementi?\n0 - random\n1 - s klaviaturi\n");
        scanf ("%i", &v);
        srand(time(0));
        switch (v)
        {
        case 0://random
                for (i=0; i<n; i++)
                        for (j=0; j<n; j++) 
                                a[i][j] = rand()%20;
                break;
        case 1:// sklavi
                for (i=0; i<n; i++)
                        for (j=0; j<n; j++)
                        {
                                printf ("a[%i][%i]= ", i+1, j+1);
                                scanf ("%i", &a[i][j]);
                        }
        }
   for (i=0; i<n; i++)
        {
                for (j=0; j<n; j++)
                {
                        printf ("%i ", a[i][j]);
                }
                printf ("\n");
        }
  system("PAUSE");
 /////////////////////////////////////////////////////// 
 for (j=0;j<(2*n);j++) s[j]=0;
  for (i=0;i<n;i++)
  {
      for (j=0;j+i<n;j++)
      {
          s[j]+=a[i][i+j];
          s[n+j]+=a[i+j][i]; 
      }      
  }
  for (j=0;j<n;j++) printf("%d\n",s[j]);
  for (j=n+1;j<(2*n);j++) printf("%d\n",s[j]);
  maxsum=-1000;
  for (j=1;j<n;j++)
      if (maxsum<s[j]) 
          maxsum=s[j];
  cout<<"Max sum"<<endl;
  printf("%d\n",maxsum);
        
  system("PAUSE");  
  return 0;
  }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.09.2014, 19:30     Найти максимум среди сумм элементов диагоналей, параллельных главной
Посмотрите здесь:

Найти максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы - C++
Задана целочисленная квадратная матрица A(N x N). Найти максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы.

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

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

Определить максимум среди сумм элементов диагоналей, параллельных главной - C++
Все необходимые данные должны передаваться им в качестве параметров. Использование глобальных переменных в функциях не допускается. Дана...

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

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

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

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

Найти максимум среди сумм элементов диагоналей, параллельных побочной диагонали - C++
Никак мозг не хочет повернуться, что бы понять как делается этот цикл for. У нас есть матрица (к примеру 5*5), надо найти максимум среди...

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

Найти максимум среди сумм модулей элементов диагоналей, параллельных побочной диагонали матрицы - C++
#include &lt;iostream&gt; #include &lt;iomanip&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; using namespace...

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


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zss
Модератор
Эксперт С++
6321 / 5905 / 1913
Регистрация: 18.12.2011
Сообщений: 15,183
Завершенные тесты: 1
05.09.2014, 19:41     Найти максимум среди сумм элементов диагоналей, параллельных главной #2
C++
1
2
3
4
5
6
for (i=0;i<n;i++)
      for (j=0;j<=i;j++)
           s[i]+=a[i][j];
for (i=0;i<n-1;i++) // чтобы основная диагональ не попала 2 раза
    for (j=n-1;j>=n-i-1;j--)
           s[2*n-i-1]+=a[i][j];
-=ЮрА=-
Заблокирован
Автор FAQ
05.09.2014, 22:31     Найти максимум среди сумм элементов диагоналей, параллельных главной #3
http://www.cyberforum.ru/faq/thread4...ml#post2471770
Функция
C++
1
double getMultOfElmSubDiag(int m, int r, int c, double ** a)
- умножение заменить сложением
Ответ Создать тему
Опции темы

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