С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

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

Подсчет суммы элементов в заданном рядке/столбце/диагонали матрицы - C++

15.02.2010, 19:49. Просмотров 740. Ответов 1
Метки нет (Все метки)

Всем привет. Значит, дело такое: разработать функцию для подсчета суммы элементов заданной строки, столбца или диагонали матрицы. Сама матрица n*m. т.е. динамическая.
Вот я код набросал, но выбивает ошибку Invalid Indirection (BCB 2006).

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<iostream.h>
int summa(int* &mass, int r, int s, int p1, int p2)
{
    int i,sum=0;
 
    switch(p1)//если введено 1, то строка, 2 - столбец, 3 - диагональ
    {
      case 1:
      {
      for(i=0;i<s;i++)
      sum+=mass[p2][i];
      }
      break;
      case 2:
      {
      for(i=0;i<r;i++)
      sum += mass[i][p2];
      }
      break;
      case 3:
      {
      if(p2==1)
      for(i=0;i<s;i++)
      sum+=mass[i][i];
      else
      for(i=0;i<s;i++)
      sum+=mass[s-i][i];
      }
      break;
 
 
    }
    return sum;
}
 
int main(int argc, char* argv[])
{
    int *a,n,m,p1,p2,j1,j2;/*p1 отвечает за то, в какой части матрицы искать (1-строка, 2-столбец, 3-диагональ), p2 - номер строки, столбца или диагонали (главная или побочная)*/
    cin >> n >> m;
    a=new int[n*m];
    for(j1=0;j1<n;j1++)
    {
        for(j2=0;j2<m;j2++)
        cin >> a[j1][j2];
        cout << "\n";
    }
    cout << summa(a,n,m,p1,p2);
    system("pause");
    delete []a;
        return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.02.2010, 19:49
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Подсчет суммы элементов в заданном рядке/столбце/диагонали матрицы (C++):

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

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

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

Функция: подсчет числа отрицательных элементов массива, и суммы положительных элементов матрицы - C++
написать функцию подсчета отрицательных элементов одномерного массива А(6) и сумму положит-х эл-ов матрицы В(6x6)

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

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

1
SerЁga
32 / 32 / 4
Регистрация: 18.08.2009
Сообщений: 93
15.02.2010, 21:50 #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
52
53
54
55
#include<iostream>
using namespace std;
int summa(int** mass, int r, int s, int p1, int p2)
{
    int i,sum=0;
 
    switch(p1)//если введено 1, то строка, 2 - столбец, 3 - диагональ
    {
    case 1:
        {
            for(i=0;i<s;i++)
                sum+=mass[p2][i];
        }
        break;
    case 2:
        {
            for(i=0;i<r;i++)
                sum += mass[i][p2];
        }
        break;
    case 3:
        {
            if(p2==1)
                for(i=0;i<s;i++)
                    sum+=mass[i][i];
            else
                for(i=0;i<s;i++)
                    sum+=mass[s-i][i];
        }
        break;
 
 
    }
    return sum;
}
 
int main(int argc, char* argv[])
{
    int **a,n,m,p1,p2,j1,j2;/*p1 отвечает за то, в какой части матрицы искать (1-строка, 2-столбец, 3-диагональ), p2 - номер строки, столбца или диагонали (главная или побочная)*/
    cin >> n >> m;
cin >>p1 >>p2;//для того чтобы использовать p1 и p2 с начало нужно переменные инициализировать   
    a=new int*[n];//память под матрицу выделяется вот так
    for(int i=0;i<n;i++)
        a[i]=new int[m];
    for(j1=0;j1<n;j1++)
    {
        for(j2=0;j2<m;j2++)
            cin >> a[j1][j2];
        cout << "\n";
    }
    cout << summa(a,n,m,p1,p2);
    system("pause");
    delete []a;
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.02.2010, 21:50
Привет! Вот еще темы с ответами:

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

Алгоритм вычисления суммы элементов на главной диагонали матрицы - C++
Дана задача вычислить сумму положительных элементов на главной диагонали матрицы. Сделал данную программу: #include &quot;stdafx.h&quot; #include...

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

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


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

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

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