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

Функции: найти максимальные элементы в строках матрицы и переместить их на главную диагональ

10.02.2018, 18:55. Показов 1422. Ответов 7
Метки нет (Все метки)

Ребята, помогите пожалуйста с программой . Тема для меня новая.... Дано матрицы А(3,3), В(5,5) , С(4,4). Нужно найти максимальные элементы у строках и переместить их на главную диагональ . Ввод, вывод и преобразование сделать в виде функции . ... Я написал программу без функции , можете переделать под функцию и ещё вопрос , матрицы надо было вводить в саму программу или каждый раз одну.


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
#include <iostream>
#include <cmath>
#include <cstdlib>
#include <windows.h>
#include <math.h>
#include <stdio.h>
#include <ctype.h>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "RUSSIAN");
    int n, m;
    cout <<"Введите число n: ";
    cin >> n;
    cout <<"Введите число m: ";
    cin >> m;
    int Mat[n][m];
    int max;
    int buff;
 
 
for(int i=0; i<n; i++)
    {
        for(int j=0; j<m; j++)
        {
            cout <<"Введите элемент Mat["<< i+1 << "][" << j+1 << "]: ";
            cin >> Mat[i][j];
        }
    }
    system("cls");
 
    for(int i = 0; i < n; i++)
    {
        max = Mat[i][i];
        for(int j = 0; j < m; j++){
            if(Mat[i][j] > max)
            {
                 max = Mat[i][j];
            }
        }
 
        buff = Mat[i][i];
        Mat[i][i] = max;
        max = buff;
    }
    for(int i=0; i<n; i++)
    {
        for(int j=0; j<m; j++)
        {
            cout << Mat[i][j] << ' ' << "\t";
        }
        cout << "\n";
    }
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.02.2018, 18:55
Ответы с готовыми решениями:

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

Задан массив A(3x3). Найти максимальные элементы в строках и вывести их на главную диагональ
Помогите с решением пожалуйста) Задан массив A(3x3). Найти максимальные элементы в строках и...

Как определить максимальные элементы в строках и вывести их на главную диагональ ?
с помощью процедуры

Максимальные элементы строк и перемещение их на главную диагональ матрицы
Помогите пожалуйста)) Преобразовать матрицу В(5х5) таким образом, чтобы максимальные элементы...

7
║XLR8║
1211 / 908 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
10.02.2018, 22:32 2
Цитата Сообщение от Kostik17 Посмотреть сообщение
матрицы надо было вводить в саму программу или каждый раз одну
Хороший вопрос, не забудьте задать его Вашему преподавателю.
0
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 23
10.02.2018, 23:02  [ТС] 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
#include <iostream>
#include <cmath>
#include <cstdlib>
#include <windows.h>
#include <math.h>
#include <stdio.h>
#include <ctype.h>
 
using namespace std;
 
int [][] inputMatrix()
{
    setlocale(LC_ALL, "RUSSIAN");
    int n, m;
    cout <<"Введите число n: ";
    cin >> n;
    cout <<"Введите число m: ";
    cin >> m;
    int Mat[n][m];
 
for(int i=0; i<n; i++)
    {
        for(int j=0; j<m; j++)
        {
            cout <<"Введите элемент Mat["<< i+1 << "][" << j+1 << "]: ";
            cin >> Mat[i][j];
        }
    }
    return Mat;
}
   int [][] modifyMatrix(matrix)
   {
    int max;
    int buff;
    for(int i = 0; i < n; i++)
    {
        max = matrix[i][i];
        for(int j = 0; j < m; j++){
            if(matrix[i][j] > max)
            {
                 max = matrix[i][j];
            }
        }
 
        buff = matrix[i][i];
        matrix[i][i] = max;
        max = buff;
    }
    return matrix;
   }
 
   void outputMatrix(matrix)
   {
    for(int i=0; i<n; i++)
    {
        for(int j=0; j<m; j++)
        {
            cout << matrix([i][j] << ' ' << "\t";
        }
        cout << "\n";
    }
    return 0;
    }
Добавлено через 21 минуту
outoftime, Смысл меня подстрекать . Я думал эти три матрицы влияют на структуру , а не тупо рандом
0
║XLR8║
1211 / 908 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
10.02.2018, 23:12 4
Цитата Сообщение от Kostik17 Посмотреть сообщение
Вот чуть прошла шаманов :
Долго по "шаманам" ходить не сможешь

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
#include <iostream>
#include <cmath>
#include <cstdlib>
#include <math.h>
#include <stdio.h>
#include <ctype.h>
 
using namespace std;
 
int **inputMatrix(size_t &n, size_t &m)
{
    cout << "Введите число n: ";
    cin >> n;
    cout << "Введите число m: ";
    cin >> m;
    int **Mat = new int *[n];
    for (int i = 0; i < m; ++i)
        Mat[i] = new int[m];
 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            cout << "Введите элемент Mat[" << i + 1 << "][" << j + 1 << "]: ";
            cin >> Mat[i][j];
        }
    }
    return Mat;
}
int **modifyMatrix(int **matrix, const size_t n, const size_t m)
{
    int max;
    int buff;
    for (int i = 0; i < n; i++)
    {
        max = matrix[i][i];
        for (int j = 0; j < m; j++)
        {
            if (matrix[i][j] > max)
            {
                max = matrix[i][j];
            }
        }
 
        buff = matrix[i][i];
        matrix[i][i] = max;
        max = buff;
    }
    return matrix;
}
 
void outputMatrix(int **matrix, const size_t n, const size_t m)
{
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            cout << matrix[i][j] << ' ' << "\t";
        }
        cout << "\n";
    }
}
 
int main() {}
Поправил, хотя бы компилится.
0
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 23
10.02.2018, 23:24  [ТС] 5
Хм. Не красиво выглядит . Я уже проще сам доделаю . Спасибо за отклик
0
║XLR8║
1211 / 908 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
10.02.2018, 23:35 6
Цитата Сообщение от Kostik17 Посмотреть сообщение
Я уже проще сам доделаю
Да задача на 5 минут.
0
7245 / 4901 / 2821
Регистрация: 18.12.2017
Сообщений: 15,391
11.02.2018, 02:34 7
Kostik17, несколько моментов: 1) если Вы пишете программу для матриц с главными диагоналями -
значит это квадратные матрицы, т.е. убираем ввод m. 2) никакие buff Вам не нужны - просто присваиваете
диагональному элементу максимальное значение. 3) при расположении ввода, преобразования и вывода т.е.
всех действий в функцию (а по условию она одна) теряется смысл в самой функции (кстати в Вашей первоначальной программе они и так в функции - в функции main). уточните и сбросьте правильное условие задачи.
0
║XLR8║
1211 / 908 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
11.02.2018, 03:07 8
Лучший ответ Сообщение было отмечено Kostik17 как решение

Решение

[quote="Yetty;12109644"]
Цитата Сообщение от Yetty Посмотреть сообщение
теряется смысл в самой функции
Семантика...
Функции создаются не только для выполнения часто повторяемого кода. Они также служат логическим разделением программы. Прискорбно, что Вы и такое советуете молодым специалистам.

Цитата Сообщение от Yetty Посмотреть сообщение
при расположении ввода, преобразования и вывода т.е.
всех действий в функцию
Какой же я недалекий человек, такие перлы не могу понять. Какой образованный человек это писал, однако...

Добавлено через 16 минут
Kostik17,
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
#include <iostream>
#include <algorithm>
 
int **input(const size_t n);
void swap(int **a, const size_t n);
void show(int **a, const size_t n);
void free(int **a, const size_t n);
 
int main()
{
    int **a;
    size_t n;
    std::cin >> n;
    a = input(n);
    swap(a, n);
    show(a, n);
    free(a, n);
}
 
int **input(const size_t n)
{
    int **a = new int *[n];
    for (size_t i = 0; i < n; ++i)
    {
        a[i] = new int[n];
        for (size_t j = 0; j < n; ++j)
            std::cin >> a[i][j];
    }
    return a;
}
 
void swap(int **a, const size_t n)
{
    for (size_t i = 0; i < n; ++i)
    {
        int *max = &a[i][0];
        for (size_t j = 0; j < n; ++j)
            if (a[i][j] > *max)
                max = &a[i][j];
        std::swap(a[i][n - i - 1], *max);
    }
}
 
void show(int **a, const size_t n)
{
    for (size_t i = 0; i < n; ++i)
    {
        for (size_t j = 0; j < n; ++j)
            std::cout << a[i][j] << " ";
        std::cout << std::endl;
    }
}
 
void free(int **a, const size_t n)
{
    for (size_t i = 0; i < n; ++i)
        delete[] a[i];
    delete[] a;
}
Работает для квадратных матриц. Я меняю местами максимальный элемент и элемент на главной диагонали за счет поиска указателя на главный элемент. std::swap(a[i][n - i - 1], *max); http://en.cppreference.com/w/cpp/algorithm/swap можно руками написать.
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
11.02.2018, 03:07

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

Найти максимальные элементы каждой строки и поместить их на главную диагональ, а диагональные элементы поместить на место максимальных
Найти максимальные элементы каждой строки исходной матрицы А(N,N) (N&lt;=10) и поместить их на главную...

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

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


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

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

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