0 / 0 / 0
Регистрация: 29.11.2018
Сообщений: 22
1

Найти сумму элементов матрицы, расположенных выше главной диагонали и ниже побочной диагонали

17.02.2019, 15:03. Показов 906. Ответов 2
Метки нет (Все метки)

В строчке
C++
1
int **matrix = malloc(sizeof(int*) * rows);
выделяет функцию malloc, а в строчке
C++
1
 matrix[row] = malloc(sizeof(int) * cols);
выделяет "=". Во всех случаях пишет, что "значение типа void нельзя использовать для инициализации сущности типа "int **"

C++
1
2
3
4
5
6
7
8
int **CreateMatrix (int rows, int cols) {
    int **matrix = malloc(sizeof(int*) * rows);
    int row;
    for (row = 0; row < rows; row++) {
        matrix[row] = malloc(sizeof(int) * cols);
    }
    return matrix;
}
Вот само задание:
Дана целочисленная квадратная матрица размера n  m (n, m вводятся). Значения элементов матрицы задаются случайным образом в диапазоне [-99, 99]. Разработать программу, позволяющую находить сумму элементов матрицы, расположенных выше главной диагонали и ниже побочной диагонали.

А вот весь код

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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#include <stdlib.h>
#include <time.h>
#include <conio.h>
#include <Windows.h>
#include <iostream>
 
using namespace std;
 
 
#define hi_number   99
#define low_number -99
 
 
int **CreateMatrix (int rows, int cols);
void MatrixInput (int **matrix, int rows, int cols);
void PrintMatrix(int **matrix, int rows, int cols)
int Сумма_выше_главной_диагонали (int **matrix, int rows, int cols);
int Сумма_ниже_побочной_диагонали (int **matrix, int rows, int cols);
 
 
 
int _tmain(int argc, TCHAR* argv[])
 
{
    srand(time(NULL));
    int **matrix;
    int rows;
    int cols;
    cout << ("Введите строки матрицы:  ");
    cin >> "d", rows;
    cout << ("Введите стобцы матрицы:");
    cin >> "d", cols;
 
    matrix = CreateMatrix(rows, cols);
    MatrixInput(matrix, rows, cols);
    PrintMatrix(matrix, rows, cols);
 
    cout << ("Сумма элементов, находящихся выше главной диагонли : d\n", Сумма_выше_главной_диагонали (matrix, rows, cols));
    cout << ("Сумма элементов, находящихся ниже побочной диагонали : d\n", Сумма_ниже_побочной_диагонали (matrix, rows, cols));
 
    system("pause");
    return 0;
}
 
 
int **CreateMatrix (int rows, int cols) {
    int **matrix = malloc(sizeof(int*) * rows);
    int row;
    for (row = 0; row < rows; row++) {
        matrix[row] = malloc(sizeof(int) * cols);
    }
    return matrix;
}
 
void MatrixInput(int **matrix, int rows, int cols) {
    int row, col;
    for (row = 0; row < rows; row++) {
        for (col = 0; col < cols; col++) {
            matrix[row][col] = (rand() % (hi_number - low_number)) + low_number;
        }
    }
}
 
void PrintMatrix(int **matrix, int rows, int cols) {
    {
    int row, col;
    for (row = 0; row< rows; row++) {
        for (col = 0; col < cols; col++) {
            cin >> "[3d]  ", matrix[row][col];
        }
        cin >> "\n";
    }
}
 
int Sum_above_main_diagonal(int **matrix, int rows, int cols)
{
    int sum = 0;
    int row, col;
    for (row = 0; row < rows - 1; row++)
        for (col = row + 1; col < rows; col++)
            sum += matrix[row][col];
    return sum;
}
 
int Sum_below_anti_diagonal(int **matrix, int rows, int cols)
{
    int sum = 0;
    int row, col;
 
    for (int row = 1; row < rows; row++)
        for (int col = cols - row; col < cols; col++)
            sum += matrix[row][col];
    return sum;
}
Заранее спасибо!
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.02.2019, 15:03
Ответы с готовыми решениями:

Найти сумму элементов матрицы, расположенных выше главной диагонали и ниже побочной диагонали
Дана целочисленная квадратная матрица размера n  m (n, m вводятся). Значения элементов матрицы...

Найти сумму неотрицательных элементов матрицы выше побочной диагонали и ниже главной диагонали
Есть задание: Дана квадратная вещественная матрица размерности n. Найти сумму неотрицательных...

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

Определить сумму элементов матрицы, расположенных выше главной диагонали
Определить сумму элементов матрицы размером 10 на 10, расположенных выше главной диагонали Срочно...

2
316 / 212 / 101
Регистрация: 12.02.2019
Сообщений: 908
17.02.2019, 15:39 2
C
1
2
int **matrix = (int**)malloc(sizeof(int*) * rows);
matrix[row] = (int*)malloc(sizeof(int) * cols);
0
0 / 0 / 0
Регистрация: 29.11.2018
Сообщений: 22
17.02.2019, 15:52  [ТС] 3
Работает
Спасибо!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.02.2019, 15:52
Помогаю со студенческими работами здесь

Вычислить сумму положительных элементов матрицы, расположенных ниже главной диагонали
вычислить сумму положительных элементов А(6,6) расположеннных ниже главной диагоналей.на языке си...

Найти произведение всех элементов матрицы, расположенных на побочной диагонали и выше ее
Найти произведение всех элементов, расположенных на побочной диагонали и выше ее, матрицы размером...

Найти сумму модулей элементов, расположенных выше главной диагонали
Дана действительная квадратная матрица порядка n Найти сумму модулей элементов, расположенных выше...

Найти максимальный из элементов матрицы, расположенных выше главной диагонали
дана целочисленная квадратная матрица. Определить: 1) 2) найти максимальный из элементов,...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru