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

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

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

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

15.02.2010, 19:49. Просмотров 705. Ответов 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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.02.2010, 19:49     Подсчет суммы элементов в заданном рядке/столбце/диагонали матрицы
Посмотрите здесь:

Вычисление суммы и произведения элементов матрицы, находящихся на главной диагонали C++
Подсчет среднего арифметического элементов, расположенных на главной диагонали матрицы C++
C++ На побочной диагонали матрицы разместить суммы элементов, которые лежат той же строке и столбце
C++ На побочной диагонали матрицы разместить суммы элементов, которые лежат той же строке и столбце
C++ Заполнить матрицу случайными числами. На главной диагонали разместить суммы элементов, которые лежат на той же строке и том же столбце
C++ Вычисление суммы элементов главной диагонали матрицы
C++ На побочной диагонали разместить суммы элементов лежащие на тех же строке и столбце
Функция: нахождение суммы положительных элементов квадратной матрицы и сортировка главной диагонали C++
C++ Алгоритм вычисления суммы элементов на главной диагонали матрицы
C++ Найти суммы положительных элементов строк матрицы и присвоить их элементам побочной диагонали
Определить суммы элементов матрицы, находящихся ниже побочной диагонали C++
Найти количество нулевых элементов в і-том рядке матрицы С++ C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
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;
}
Yandex
Объявления
15.02.2010, 21:50     Подсчет суммы элементов в заданном рядке/столбце/диагонали матрицы
Ответ Создать тему
Опции темы

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