Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 6
1

В заданной квадратной матрице размера (2n+1)×(2n+1) поменять местами среднюю строку и главную диагональ

19.06.2019, 09:22. Просмотров 1948. Ответов 1
Метки нет (Все метки)


В заданной квадратной матрице размера (2n+1)×(2n+1) поменять местами среднюю строку и главную диагональ
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
#include<iostream>
#include<stdio.h>
#include<math.h>
#include <locale.h>
#include <conio.h>
 
using namespace std;
const int RAZ = 10;
typedef int telem;
typedef int tmas[RAZ][RAZ];
 
void inputmas(tmas a, int &x, int &y);
 
void outputmas(tmas a, int &x, int &y);
 
void minimum(tmas a, int &x, int &y, int &min, bool &flag);
 
int main() {
    setlocale(LC_ALL, "Russian");
    tmas a;
    int x, y;
    int min;
    bool flag;
    inputmas(a, x, y);
    cout << "Исходная матрица: \n";
    outputmas(a, x, y);
    minimum(a, x, y, min, flag);
    if (flag) {
        cout << "Обработанная матрица: \n";
        outputmas(a, x, y);
    }
    system("pause");
    return 0;
}
 
void inputmas(tmas a, int &x, int &y) {
    int i, j;
    cout << "Введите размер матрицы через пробел: \n";
    cin >> x >> y;
    cout << "Введите матрицу: \n";
    for (i = 0; i < x; i++) {
        for (j = 0; j < y; j++) {
            cin >> a[i][j];
        }
    }
}
 
void minimum(tmas a, int &x, int &y, int &min, bool &flag) {
    int i, j, k;
    flag = 0;
    for (i = 0; i < x; i++) {
        for (j = 0; j < y; j++) {
            if (a[i][j] >= 0) {
                k = a[i][j];
                flag = 1;
            }
        }
    }
    for (i = 0; i < x; i++) {
        for (j = 0; j < y; j++) {
            if (a[i][j] > 0) {
                if (k > a[i][j]) {
                    k = a[i][j];
                    min = j;
                }
            }
        }
    }
 
    if (flag) {
        for (int i = 0; i < x; i++) {
            k = a[i][min];
            a[i][min] = a[i][y - 1];
            a[i][y - 1] = k;
        }
    }
    else
        cout << "Нет положительных значений" << endl;
}
 
void outputmas(tmas a, int &x, int &y) {
    int i, j;
    for (i = 0; i < x; i++) {
        for (j = 0; j < y; j++) {
            cout << a[i][j] << " ";
        }
        cout << "\n";
    }
}
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.06.2019, 09:22
Ответы с готовыми решениями:

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

В квадратной матрице поменять местами главную диагональ со строкой содержащей максимальный элемент
Дана прямоугольная матрица nxm целых чисел (n,m&lt;10 – ввод с клавиатуры, значения элементов массива...

Поменять местами побочную и главную диагональ в матрице
Здравствуйте. Помогите, пожалуйста, написать программу которая меняет побочную и главную диагональ...

Поменять местами строки, столбцы в матрице (чтобы упорядочить главную диагональ)
Здравствуйте, помогите пожалуйста дорешать задачу: Разработать функцию, которая проверяет,...

1
Модератор
Эксперт С++
10422 / 8688 / 5251
Регистрация: 18.12.2011
Сообщений: 23,225
19.06.2019, 10:02 2
Лучший ответ Сообщение было отмечено frika_panda как решение

Решение

Ну что-ж осталось только переделать функцию
C++
1
2
3
4
5
6
7
8
9
void minimum(tmas a, int &x, int &y, int &min, bool &flag) {
    int L=x>y?y:x;
    for (int i = 0; i < L; i++) {
        int k=a[i][i];
        a[i][i]=a[x/2][i];
       a[x/2][i]=k;
    }
    flag = true;
 }
Параметр min не используется
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.06.2019, 10:02

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь или здесь.

Поменять местами 1-ю строку и главную диагональ матрицы.
Добрый день!Ребят,очень нужна ваша помощь,в решении задачи!Помогите,сижу на экзамене,в голову...

Поменять местами первую строку и главную диагональ матрицы.
Если в матрице количество отрицательных элементов в четных строках больше количества положительных...

Поменять местами первую строку и главную диагональ матрицы.
Задача 8 uses crt; const nmax=20; var a:array of integer; n,i,j,kp,ko:byte; x:integer;...

В заданной квадратной матрице размера 2n*2n поменять местами значения элементов строк области [1+2+3] и элементов столбц
В заданной квадратной матрице размера 2n*2n поменять местами значения элементов строк области и...


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

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

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