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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
aNastya
0 / 0 / 0
Регистрация: 16.02.2012
Сообщений: 6
18.02.2012, 19:25     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю #1
Есть задача. Использование функций-шаблонов: для работы с двумерными массивами арифметических типов данных разработать шаблоны ввода и вывода мыссива, а также шаблон для решения основной задачи:
Подсчитать среднее арифметическое ненулевых эементов, расположенных над побочной диагональю.

Прошу помочь, сама даже не имею шаблона, благодаря которому могла бы сделать задачку.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.02.2012, 19:25     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю
Посмотрите здесь:

Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю C++
C++ Дан массив размером n×n. Подсчитать среднее арифметическое, расположенных над побочной диагональю
Подсчитать произведение отрицательных элементов, расположенных под побочной диагональю матрицы C++
C++ Подсчитать количество нулевых элементов массива, расположенных над и под главной диагональю
C++ Подсчитать среднее арифметическое значение нечетных элементов матрицы, расположенных выше главной диагонали
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dimcoder
Полярный
 Аватар для dimcoder
449 / 422 / 66
Регистрация: 11.09.2011
Сообщений: 1,108
18.02.2012, 19:48     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от aNastya Посмотреть сообщение
шаблоны ввода и вывода мыссива
Вот первая часть задачи:
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
#include <cstdlib>
#include <iostream>
#include <iomanip>
 
using namespace std;
 
template <class T>
void vvod(T **a, int m, int n)
{
    cout << "Vvedite massiv: " <<  m << " * " << n << endl;
    for (int i = 0; i < m; i++)
       for (int j = 0; j < n; j++)
          cin >> a[i][j];
}
 
template <class T>
void vivod(T **a, int m, int n)
{
    cout << "Massiv: " <<  m << " * " << n << endl;
    for (int i = 0; i < m; i++)
    {
       for (int j = 0; j < n; j++)
          cout << setw(6) << a[i][j] << " "; 
       cout << endl;
    }
}
 
int main(int argc, char *argv[])
{
    int **a = new int*[3];
    for (int i = 0; i < 4; i++)
       a[i] = new int[20];
       
    double **b = new double*[3];
    for (int i = 0; i < 4; i++)
       b[i] = new double[20];
       
    vvod(a, 3, 4);
    vvod(b, 3, 4);
    vivod(a, 3, 4);
    vivod(b, 3, 4);
    system("PAUSE");
    return EXIT_SUCCESS;
}
Так будет выглядеть функция по вычислению до диагонали:

C++
1
2
3
4
5
6
template <class T>
T sum(T **a, int m, int n)
{
//Здесь вычисляете
return s;
}
aNastya
0 / 0 / 0
Регистрация: 16.02.2012
Сообщений: 6
18.02.2012, 21:23  [ТС]     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю #3
C++
1
2
3
4
5
6
7
    int **a = new int*[3];
    for (int i = 0; i < 4; i++)
       a[i] = new int[20];
       
    double **b = new double*[3];
    for (int i = 0; i < 4; i++)
       b[i] = new double[20];
Поясните пожалуйста этот кусочек вкратце.
lvlkoo
.NET C#,ASP.NET MVC
 Аватар для lvlkoo
304 / 260 / 89
Регистрация: 16.10.2010
Сообщений: 1,167
Завершенные тесты: 1
18.02.2012, 21:27     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю #4
Выделение памяти для двумерного массива
HardMorg
2 / 25 / 3
Регистрация: 29.08.2010
Сообщений: 204
18.02.2012, 21:35     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю #5
Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
template <class T>
T average(T **a, int m, int n)
{
    T sum = 0;
    int count = 0;
    for(int i = 0; i < m; i++) {
        for(int j = i; j < n - 1; j++)
                    if(a[i][j] != 0) {
                        sum += a[i][j];
                        ++count;
                   }
   }
 
   if(count == 0)
      return 0;
 
   return sum / count;
}
а вот вторая часть программы

Добавлено через 4 минуты
Цитата Сообщение от lvlkoo Посмотреть сообщение
Выделение памяти для двумерного массива
объявляем int** указатель на указатель и выделяем динамически память(сначала количество строк new int*[3]; а потом количество столбцов в цикле для каждого стоки a[i] = new int[20] получится матрица
3 х 20, только цикл там неверный он должен идти до 3 а не до 4
Yandex
Объявления
18.02.2012, 21:35     Подсчитать среднее арифметическое ненулевых элементов матрицы, расположенных над побочной диагональю
Ответ Создать тему
Опции темы

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