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

Замена местами строки, содержащие минимальную и максимальную сумму элементов

09.09.2019, 20:35. Показов 2054. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Код который указан ниже работает так: Создаёт массив 7 на 7 и меняет строки местами 1 с 4, и 5 с 7. Подскажите как сделать чтоб программа меняла местами строки, содержащие минимальную и максимальную сумму элементов?


#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;

int main()
{
setlocale(LC_ALL, "Russian");
srand((int)time(0));
const int n = 7;
double a[n][n];
int from = 0; int to = 0;
cout << "Введите границу массива (левая): "; cin >> from;
cout << "Введите границу массива(правая): "; cin >> to;
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
a[i][j] = rand() % to + from;
cout << a[i][j] << " ";
}
cout << "\n";
}
cout << "\n";

swap(a[4], a[6]);
swap(a[1], a[3]);

for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
cout << a[i][j] << " ";
cout << "\n";
}

system("pause");
return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.09.2019, 20:35
Ответы с готовыми решениями:

Дан двумерный массив.посчитать сумму элементов в кажой строке. найти максимальную и минимальную сумму и помень эти строки местами.
Дан двумерный массив.посчитать сумму элементов в кажой строке. найти максимальную и минимальную сумму и помень эти строки местами. Я...

Поменять местами строки, содержащие минимальную и максимальную суммы абсолютных значений
Доброго времени суток! Помогите пожалуйста написать код. Дана целочисленная прямоугольная таблица размером m×n. Поменять местами...

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

3
 Аватар для Andrey B
170 / 122 / 61
Регистрация: 06.02.2015
Сообщений: 300
09.09.2019, 21:14
Лучший ответ Сообщение было отмечено Llamalass как решение

Решение

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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
int main(){
    setlocale(LC_ALL, "Russian");
    srand((int)time(NULL));
    const int n = 7;
    double a[n][n];
    int from = 0; 
    int to = 0;
    int id_max = 0;
    int id_min = 0;
 
    double maxp_temp = 0;
    double minp_temp = 0;
 
    double maxp = 0;
    double minp = 99999;
    
    cout << "Введите границу массива (левая): "; cin >> from;
    cout << "Введите границу массива(правая): "; cin >> to;
    
    for (int i = 0; i < n; i++){
        for (int j = 0; j < n; j++){
            a[i][j] = rand() % to + from;
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
 
    cout << endl;
 
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            maxp_temp = maxp_temp + a[i][j];
            minp_temp = minp_temp + a[i][j];
        }
 
        cout << "i: " << i << " " << maxp_temp << endl;
 
        if (maxp_temp > maxp) {
            maxp = maxp_temp;
            id_max = i;
        }
 
        if (minp_temp < minp) {
            minp = minp_temp;
            id_min = i;
        }
 
        maxp_temp = 0;
        minp_temp = 0;
    }
 
    cout << "Max " << endl;
    for (int i = 0; i < n; i++) {
        cout << a[id_max][i]<< " ";
    }
 
    cout << endl;
    cout << "Min " << endl;
    for (int i = 0; i < n; i++) {
        cout << a[id_min][i] << " ";
    }
 
    cout << endl << endl;
    
    /*поменять местами строчки с индексами id_min и id_max*/
    
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
 
    system("pause");
    return 0;
}
где строка с комментарием нужно написать как менять строчки местами. Если понял код из своего вопроса, то справишься.

p.s. оформляй темы при помощи тегов языков программирования

p.p.s посмотри в интернете как задавать двумерные массивы при помощи
C++
1
new
p.p.p.s как задание для саморазвития. Измени код, чтобы была 1 переменная в которой сумма элементов строки
1
0 / 0 / 0
Регистрация: 09.09.2019
Сообщений: 3
09.09.2019, 21:41  [ТС]
Огромное спасибо)
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
09.09.2019, 21:44
Цитата Сообщение от Llamalass Посмотреть сообщение
Подскажите как сделать чтоб программа меняла местами строки, содержащие минимальную и максимальную сумму элементов?
например разные (по составу) строки 4 и 6 имеют одинаковую минимальную сумму элементов, а строки 1,5,7 одинаковую максимальную сумму. что на что меняем ? уточните условие.
Цитата Сообщение от Llamalass Посмотреть сообщение
a[i][j] = rand() % to + from;
Цитата Сообщение от Andrey B Посмотреть сообщение
a[i][j] = rand() % to + from;
лучше так:
C++
1
a[i][j] = rand() % (to - from + 1) + from;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.09.2019, 21:44
Помогаю со студенческими работами здесь

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

Найти максимальную и минимальную строку и поменять их местами
помогите пожалуйста!!! Я не могу написать программу на Паскале!!!=( ...вот задание: Найти максимальную и минимальную строку и поменять...

Поменять местами максимальную и минимальную цифры в записи числа х
Поменять местами максимальную и минимальную цифры в записи числа х

Поменять местами максимальную и минимальную цифру заданного числа
Дано число n. Поменять местами максимальную и минимальную цифру.

Найти в файле максимальную и минимальную компоненты и поменять их местами
Дан файл G, компонентами которого являются вещественные числа. Найти в нем максимальную и минимальную компоненты и поменять их местами....


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru