9 / 4 / 2
Регистрация: 29.11.2018
Сообщений: 215
1

Вычислить количество побочных диагоналей в прямоугольной матрице

26.11.2019, 12:12. Показов 3227. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Я знаю, как вычислить количество побочных диагоналей в квадратной матрице, а от в прямоугольной не знаю как. Подскажите, пожалуйста, ибо у меня в задача такова: Дана прямоугольная матрица. Определить минимум среди сумм модулей элементов диагоналей, параллельных побочной диагонали матрицы.
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
#include <iostream>
#include <math.h>
#define N 5
#define CAP N*2-1 // количество побочный диагоналей в квадратной матрице 
// равно удвоенная размерность минус 1
 
using namespace std;
int findMax(int arr[CAP]){
    int Min = arr[0];
    for (int i = 0; i < CAP; i++){
        if (arr[i] < Min)
            Min = arr[i];
    }
    return Min;
}
 
int main(){
    setlocale(0, "");
 
    int matrix[N][N];
    int arr[CAP] = { 0 }; // 9
    for (int i = 0; i < N; i++){
        for (int j = 0; j < N; j++){
            matrix[i][j] = rand() % 25;
        }
    }
 
    for (int i = 0; i < N; i++){
        for (int j = 0; j < N; j++){
            cout << "\t" << matrix[i][j];
            arr[i + j] += abs(matrix[i][j]);
        }
        cout << endl;
    }
    cout << findMax(arr) << endl;
    return 0;
}
Добавлено через 2 часа 3 минуты
Я немного редактировал код:
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <math.h>
#include <time.h>
 
using namespace std;
void create(int** arr, int& m, int& n) {
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++)
            arr[i][j] = rand() % 25-5;
    }
}
void show(int** arr, int& m, int& n) {
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++)
            cout << arr[i][j] << "\t";
        cout << endl;
    }
}
void sum(int** arr, int& m, int& n) {
    int sum, i;
    for (int j = 0; j < m; ++j) {
        sum = 0;
        for (i = 0; i < n; ++i) {
            if (arr[i][j] < 0)
                break;
            sum += arr[i][j];
        }
        if (i == m)
            cout << "sum" << j << " = " << sum << "\n";
    }
}
int main() {
    setlocale(0, "");
    srand(time(NULL));
    int n, m;
    cin >> m >> n;
    int** matrix = new int* [m];
    for (int i = 0; i < m; i++)
        matrix[i] = new int[n];
    
    create(matrix, m, n);
    show(matrix, m, n);
    sum(matrix, m, n);
    
        /*int findMax(int arr[CAP]) {
            int Min = arr[0];
            for (int i = 0; i < CAP; i++) {
                if (arr[i] < Min)
                    Min = arr[i];
            }
            return Min;
        }*/
        /*int arr[CAP] = { 0 }; // 9
                for (int i = 0; i < n; i++) {
                    for (int j = 0; j < m; j++) {
                        matrix[i][j] = rand() % 25 - 5;
                    }
                }
 
                for (int i = 0; i < n; i++) {
                    for (int j = 0; j < m; j++) {
                        cout << "\t" << matrix[i][j];
                        arr[i + j] += abs(matrix[i][j]);
                    }
                    cout << endl;
                }
                cout << findMax(arr) << endl;*/
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
26.11.2019, 12:12
Ответы с готовыми решениями:

Вычислить произведения элементов побочных диагоналей матриц A(n,n) и B(m,m)
Помогите пожалуйста!

Вычислить произведения элементов побочных диагоналей матриц A(n,n) и B(m,m)
Вычислить произведения элементов побочных диагоналей матриц A(n,n) и B(m,m)

Вычислить разность суммы главных и побочных диагоналей матрицы
Нужно составить программу которая у двух массивов размерностью NxN вычисляет разность суммы главных...

В прямоугольной матрице выявить все квадратные подматрицы, у которых суммы элементов обеих диагоналей равны.
Задание: &quot;В прямоугольной матрице выявить все квадратные подматрицы, у которых суммы элементов...

2
6104 / 3460 / 1404
Регистрация: 07.02.2019
Сообщений: 8,786
26.11.2019, 12:24 2
Цитата Сообщение от Pavlory Посмотреть сообщение
а от в прямоугольной не знаю как.
n+m-1
0
9 / 4 / 2
Регистрация: 29.11.2018
Сообщений: 215
26.11.2019, 13:15  [ТС] 3
Цитата Сообщение от zayats80888 Посмотреть сообщение
n+m-1
Я пробовал так сделать, ошибку выбивает: Run-Time Check Failure #2 - Stack around the variable 'matrix' was corrupted.
0
26.11.2019, 13:15
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
26.11.2019, 13:15
Помогаю со студенческими работами здесь

Смена побочных диагоналей матрицы
Помогите с созданием программы. Нужно написать программу которая меняет местами побочные диагонали...

Сформировать вектор из главных и побочных диагоналей
Нужно сформировать вектор из главных и побочных диагоналей матрицы и найти их сумму . Матрица 5X5...

В прямоугольной матрице определить количество строк
В прямоугольной матрице определить количество строк, элементы которых полностью упорядочены по...

Определить количество единичных диагоналей в матрице
Задан квадратный массив А из N строк и N столбцов, элементы которого нули и единицы.Установить в...


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

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

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