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

Вычислить суммы элементов главной и побочной диагоналей массива. - C++

Восстановить пароль Регистрация
 
I3I
0 / 0 / 0
Регистрация: 28.09.2014
Сообщений: 83
20.11.2014, 14:32     Вычислить суммы элементов главной и побочной диагоналей массива. #1
a)Элементы двухмерного массива являются действительными числами. Размерность массива и значения его элементов задано пользователем. Вычислить суммы элементов главной и побочной диагоналей массива.
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
#include <iostream>
#include <conio.h>
 
using namespace std;
 
int main()  {
    setlocale(LC_ALL, "Russian");
    int n,m,i;
    double sum_main_diag = 0, sum_collateral_diag = 0;
    cout<<"Введте розмерность масива: ";
    cin>>n>>m;
    int **arr;
    arr=new int*[n];
    for (i=0;i<n;i++)
        arr[i]=new int [m];
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            cin>>*(*(arr+i)+j);
    for(int i=0;i<=n;i++)
        for(int j=0;j=i;j++)
        //Если главная диагональ
            if(i == j){
                sum_main_diag += *(*(arr+i)+j);
for(int i=n-1;i<n;i--)
        for(int j=0;j<m;j++)
            //Если побочная диагональ
            if(i == (n - 1) - j)  {
                sum_collateral_diag +=*(*(arr+i)+j);
            } 
            }    
    cout << "Сумма главной диагонали: " << sum_main_diag << endl;
    cout << "Сумма побочной: " << sum_collateral_diag << endl;
 
    getch();
    return 0;
}
б)Определить, есть полученные суммы взаимно простыми, если их абсолютные значения округлить до целого.

Добавлено через 1 минуту
Цитата Сообщение от I3I Посмотреть сообщение
sum_collateral_diag +=*(*(arr+i)+j);
тут ошибку выдает помогите поправить код.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.11.2014, 14:32     Вычислить суммы элементов главной и побочной диагоналей массива.
Посмотрите здесь:

C++ Сформировать одномерный массив, элементами которого являются средние арифметические значения элементов главной и побочной диагоналей
поменять местами элементы главной и побочной диагоналей... C++
Поменять местами максимальный элемент главной диагонали и элемент, лежащий на пересечении главной и побочной диагоналей C++
C++ Динамический массив: вычислить сумму элементов главной и побочной диагоналей (Исправление кода)
Дана квадратная матрица порядка M. Найти суммы элементов ее диагоналей, параллельных главной (начиная с одноэлементной диагонали A[1,M]) C++
Посчитать суммы в четвертях матрицы которые образуются пересечением главной и побочной диагоналей. C++
Найти среднее арифметическое положительных элементов главной и побочной диагоналей матрицы C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zss
Модератор
Эксперт С++
 Аватар для zss
5942 / 5547 / 1783
Регистрация: 18.12.2011
Сообщений: 14,155
Завершенные тесты: 1
20.11.2014, 14:45     Вычислить суммы элементов главной и побочной диагоналей массива. #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
#include <iostream>
using namespace std;
int main()  
{
    setlocale(LC_ALL, "Russian");
    int n,m,i;
    double sum_main_diag = 0, sum_collateral_diag = 0;
    cout<<"Введите размерность масива: n m";
    cin>>n>>m;
    int **arr;
    arr=new int*[n];
    for (i=0;i<n;i++)
        arr[i]=new int [m];
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            cin>>*(*(arr+i)+j);
    for(int i=0;i<n;i++)
    {
        //Если главная диагональ
       sum_main_diag += *(*(arr+i)+i);
        //Если побочная диагональ
       sum_collateral_diag +=*(*(arr+i)+n-i-1);
    } 
    cout << "Сумма главной диагонали: " << sum_main_diag << endl;
    cout << "Сумма побочной: " << sum_collateral_diag << endl;
 
    system("pause");
    return 0;
}
I3I
0 / 0 / 0
Регистрация: 28.09.2014
Сообщений: 83
20.11.2014, 22:47  [ТС]     Вычислить суммы элементов главной и побочной диагоналей массива. #3
Цитата Сообщение от I3I Посмотреть сообщение
б)Определить, есть полученные суммы взаимно простыми, если их абсолютные значения округлить до целого.
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
#include <iostream>
#include <conio.h>
using namespace std;
 
 
int main()  
{
    setlocale(LC_ALL, "Russian");
    int n,m,i;
    double sum_main_diag = 0, sum_collateral_diag = 0;
    cout<<"Введите размерность масива: n m";
    cin>>n>>m;
    int **arr;
    arr=new int*[n];
    for (i=0;i<n;i++)
        arr[i]=new int [m];
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            cin>>*(*(arr+i)+j);
    for(int i=0;i<n;i++)
    {
        //Если главная диагональ
       sum_main_diag += *(*(arr+i)+i);
        //Если побочная диагональ
       sum_collateral_diag +=*(*(arr+i)+n-i-1);
    } 
    cout << "Сумма главной диагонали: " << sum_main_diag << endl;
    cout << "Сумма побочной: " << sum_collateral_diag << endl;
    while (sum_main_diag != sum_collateral_diag)
  if (sum_main_diag > sum_collateral_diag)
    sum_main_diag -= sum_collateral_diag;
  else
      sum_collateral_diag -= sum_main_diag;
if(sum_main_diag != 1 )
    cout<<"Cуммы не взаимно простые";
else sum_main_diag = 1;
cout<<"Cуммы взаимно простые";
    getch();
    return 0;
Добавлено через 42 секунды
Цитата Сообщение от I3I Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
while (sum_main_diag != sum_collateral_diag)
if (sum_main_diag > sum_collateral_diag)
 sum_main_diag -= sum_collateral_diag;
 else
 sum_collateral_diag -= sum_main_diag;
if(sum_main_diag != 1 )
cout<<"Cуммы не взаимно простые";
else sum_main_diag = 1;
cout<<"Cуммы взаимно простые"
;
тут тоже что-то не так(((
Yandex
Объявления
20.11.2014, 22:47     Вычислить суммы элементов главной и побочной диагоналей массива.
Ответ Создать тему
Опции темы

Текущее время: 10:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru