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

В заданной матрице поменять строку, содержащую максимальный элемент со строкой, содержащей минимальный элемент

10.09.2016, 11:06. Показов 2505. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В данной действительной квадратной матрице размера

m x n поменять строку, содержащую элемент с наибольшим значением со строкой, содержащей элемент с наименьшим значением. Предполагается, что эти элементы единственны.
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
#include "stdafx.h"
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
 
    setlocale(LC_ALL,"rus");
    srand(time(0));
        int m;
        int n;
    cout<< "Введите M";
    cin >> m;
    cout << "Введите N";
    cin >>n;
    int arr1[m][n];
    for (int i = 0; i < m; i++)
        for (int j = 0; j < n; j++)
            arr1[i][j]=rand()%100;
    cout<<"Исходный массив: "<<endl;
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < 3; j++)
            cout<<arr1[i][j]<<" ";
        cout<<endl;
    }
    int max,rowMax=0;
    int min,rowMin=0;
    max=arr1[0][0];
    min=arr1[0][0];
    for (int i = 0; i < m; i++)
        for (int j = 0; j < n; j++)
        {
            if(max<arr1[i][j])
            {
                max=arr1[i][j];
                rowMax=i;
            }
            if(min>arr1[i][j])
            {
                min=arr1[i][j];
                rowMin=i;
            }
        }
    int temp;
    for (int i = 0; i < m; i++)
    {
        temp=arr1[rowMax][i];
        arr1[rowMax][i]=arr1[rowMin][i];
        arr1[rowMin][i]=temp;
    }
    cout<<"Массив после замены строк: "<<endl;
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < 3; j++)
            cout<<arr1[i][j]<<" ";
        cout<<endl;
    }
    system("pause");
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.09.2016, 11:06
Ответы с готовыми решениями:

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

Поменять местами строку, содержащую максимальный элемент массива, со строкой, содержащей минимальный элемент массива
сложно дались массивы, помогите написать код. Дан вещественный массив А. Поменять местами строку,...

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

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

3
252 / 158 / 118
Регистрация: 26.11.2012
Сообщений: 384
10.09.2016, 11:46 2
Лучший ответ Сообщение было отмечено mihaangel как решение

Решение

Что не так?

Добавлено через 14 минут
В цикле замены была ошибка
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 <ctime>
using namespace std;
 
int main()
{
 
    setlocale(LC_ALL,"rus");
    srand(time(0));
    int m = 5;
    int n = 4;
    int arr1[m][n];
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            arr1[i][j] = rand() % 100;
    }
    cout << "Исходный массив: " << endl;
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            cout << arr1[i][j] << " ";
        cout << endl;
    }
    
    int max, rowMax = 0;
    int min, rowMin = 0;
    max = min = arr1[0][0];
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++){
            if(max < arr1[i][j]){
                max = arr1[i][j];
                rowMax = i;
            }
            if(min > arr1[i][j]){
                min = arr1[i][j];
                rowMin = i;
            }
        }
    }
    
    cout << "min " << min << " max " << max << endl;
    
    int temp;
    for (int i = 0; i < n; i++)
    {
        temp = arr1[rowMax][i];
        arr1[rowMax][i] = arr1[rowMin][i];
        arr1[rowMin][i] = temp;
    }
    cout<<"Массив после замены строк: " << endl;
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            cout << arr1[i][j] <<" ";
        cout << endl;
    }
    return 0;
}
Добавлено через 2 минуты
код практически не правил, в основном только пробелы и фигурные скобки, но посмотри на сколько лучше смотреть на такой код.
1
0 / 0 / 0
Регистрация: 09.09.2016
Сообщений: 7
10.09.2016, 21:17  [ТС] 3
Спасибо. Буду работать над кодом

Добавлено через 4 минуты
вопрос в том еще, что выдает ошибки
C++
1
2
3
4
 srand(time(0));
    int m = 5;
    int n = 4;
    int arr1[m][n];
невозможно выделить память для массива постоянного нулевого размера
0
252 / 158 / 118
Регистрация: 26.11.2012
Сообщений: 384
10.09.2016, 21:50 4
Лучший ответ Сообщение было отмечено mihaangel как решение

Решение

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
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
 
    setlocale(LC_ALL,"rus");
    srand(time(0));
    int m = 5;
    int n = 4;
    int **arr1 = new int*[m];
    for(int i = 0; i < m; i++)
        arr1[i] = new int[n];
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            arr1[i][j] = rand() % 100;
    }
    cout << "Исходный массив: " << endl;
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            cout << arr1[i][j] << " ";
        cout << endl;
    }
    
    int max, rowMax = 0;
    int min, rowMin = 0;
    max = min = arr1[0][0];
    
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++){
            if(max < arr1[i][j]){
                max = arr1[i][j];
                rowMax = i;
            }
            if(min > arr1[i][j]){
                min = arr1[i][j];
                rowMin = i;
            }
        }
    }
    
    cout << "min " << min << " max " << max << endl;
    
    int temp;
    for (int i = 0; i < n; i++)
    {
        temp = arr1[rowMax][i];
        arr1[rowMax][i] = arr1[rowMin][i];
        arr1[rowMin][i] = temp;
    }
    cout<<"Массив после замены строк: " << endl;
    for (int i = 0; i < m; i++){
        for (int j = 0; j < n; j++)
            cout << arr1[i][j] <<" ";
        cout << endl;
    }
    
    for(int i = 0; i < m; i++)
        delete []arr1[i];
    delete []arr1;
    
    return 0;
}
2
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.09.2016, 21:50
Помогаю со студенческими работами здесь

В данной действительной матрице размера 3Х3 поменять местами строку, содержащую элемент с наибольшим значе-нием, со строкой, содержащей элемент с наим
В данной действительной матрице размера 3Х3 поменять местами строку, содержащую элемент с...

В матрице поменять местами строку, содержащую наибольший элемент, со строкой, содержащей наименьший
Задание: В данной действительной матрице размера mn поменять местами строку, содержащую элемент...

В матрице поменять местами строку, содержащую элемент с наибольшим значением, со строкой, содержащей элемент с наименьшим значением
В данной действительной матрице размера 3*3 поменять местами строку, содержащую элемент с...

Поменять местами строку, содержащую элемент с наибольшим значением, со строкой, содержащей элемент с наименьшим значение
Добрый день, помогите пожалуйста переделать программу #include &lt;iostream&gt; using namespace...


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

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

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