Язык C++. Сформировать двухмерный динамический массив целых чисел. Переставить строки массива в соответствии с увеличением суммы элементов строк.

21 Сен 2019 в 00:42
182 +1
0
Ответы
1

Пример решения:

#include <iostream>
using namespace std;
int main() {
int n, m;
cout << "Введите количество строк и столбцов массива: ";
cin >> n >> m;
int **arr = new int*[n];
for (int i = 0; i < n; i++) {
arr[i] = new int[m];
}
// Заполнение массива
cout << "Введите элементы массива:\n";
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cin >> arr[i][j];
}
}
// Сумма элементов строк
int *sum = new int[n];
for (int i = 0; i < n; i++) {
sum[i] = 0;
for (int j = 0; j < m; j++) {
sum[i] += arr[i][j];
}
}
// Сортировка строк по увеличению суммы элементов
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (sum[j] > sum[j + 1]) {
swap(arr[j], arr[j + 1]);
swap(sum[j], sum[j + 1]);
}
}
}
// Вывод отсортированного массива
cout << "Отсортированный массив:\n";
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cout << arr[i][j] << " ";
}
cout << endl;
}
return 0;
}

В данном примере создается двумерный динамический массив arr размером n x m. Затем заполняется и вычисляется сумма элементов строк. Строки массива сортируются по возрастанию суммы элементов. Наконец, выводится отсортированный массив.

19 Апр в 20:53
Не можешь разобраться в этой теме?
Обратись за помощью к экспертам
Название заказа не должно быть пустым
Введите email
Бесплатные доработки
Гарантированные бесплатные доработки
Быстрое выполнение
Быстрое выполнение от 2 часов
Проверка работы
Проверка работы на плагиат
Интересные статьи из справочника
Поможем написать учебную работу
Название заказа не должно быть пустым
Введите email
Доверьте свою работу экспертам
Разместите заказ
Наша система отправит ваш заказ на оценку 92 371 автору
Первые отклики появятся уже в течение 10 минут
Прямой эфир