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

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

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

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

20.11.2014, 14:32. Просмотров 259. Ответов 2
Метки нет (Все метки)

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);
тут ошибку выдает помогите поправить код.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.11.2014, 14:32
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Вычислить суммы элементов главной и побочной диагоналей массива. (C++):

Динамический массив: вычислить сумму элементов главной и побочной диагоналей (Исправление кода) - C++
я скатал у друга готовую задачу и преподаватель решил на защиту изменить мне условие #include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include...

Посчитать суммы в четвертях матрицы которые образуются пересечением главной и побочной диагоналей. - C++
дана матрица A Посчитать суммы в четвертях матрицы которые образуются пересечением главной и побочной диагоналей. Помоги,СРОЧНО! ...

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

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

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

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

2
zss
Модератор
Эксперт С++
6475 / 6038 / 1980
Регистрация: 18.12.2011
Сообщений: 15,636
Завершенные тесты: 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;
}
1
I3I
0 / 0 / 0
Регистрация: 28.09.2014
Сообщений: 87
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уммы взаимно простые"
;
тут тоже что-то не так(((
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.11.2014, 22:47
Привет! Вот еще темы с ответами:

Заменить элементы главной и побочной диагоналей матрицы на минимальный элемент ниже главной диагонали - C++
В квадратной матрице А заменить элементы главной и побочной диагоналей на минимальный элемент, найденный среди элементов, расположенных...

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

Поменять местами максимальный элемент главной диагонали и элемент, лежащий на пересечении главной и побочной диагоналей - C++
В квадратной матрице А поменять местами максимальный элемент главной диагонали и элемент, лежащий на пересечении главной и побочной...

Переставить местами элементы главной и побочной диагоналей - C++
Кто знает, как ето сделать, ничего не получаеться..(( Дано натуральное число n, определяющий количество строк и столбцов в де- которой...


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

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

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