Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 09.09.2016
Сообщений: 7

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

10.09.2016, 11:06. Показов 3017. Ответов 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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.09.2016, 11:06
Ответы с готовыми решениями:

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

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

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

3
252 / 158 / 118
Регистрация: 26.11.2012
Сообщений: 384
10.09.2016, 11:46
Лучший ответ Сообщение было отмечено 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  [ТС]
Спасибо. Буду работать над кодом

Добавлено через 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
Лучший ответ Сообщение было отмечено 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.09.2016, 21:50
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru