Упорядочить строки матрицы так, чтобы последние их элементы образовывали возрастающую последовательность - Turbo Pascal

Узнай цену своей работы

Формулировка задачи:

т.е. отсортировать не сами последние элементы,а поменять местами строки, чтобы последние элементы были отсортированы. Заранее благодарю за помощь.

Решение задачи: «Упорядочить строки матрицы так, чтобы последние их элементы образовывали возрастающую последовательность»

textual
Листинг программы
  1. uses crt;
  2. const nmax=10;
  3. var a:array[1..nmax,1..nmax] of integer;
  4.     m,n,i,j,k,imx,buf:integer;
  5. begin
  6. clrscr;
  7. randomize;
  8. repeat
  9. write('Количество строк от 2 до ',nmax,' m=');
  10. readln(m);
  11. until m in [2..nmax];
  12. repeat
  13. write('Количество столбцов от 2 до ',nmax,' n=');
  14. readln(n);
  15. until n in [2..nmax];
  16. writeln('Исходный массив:');
  17. for i:=1 to m do
  18.  begin
  19.   for j:=1 to n do
  20.    begin
  21.     a[i,j]:=random(50);
  22.     write(a[i,j]:3)
  23.    end;
  24.   writeln;
  25.  end;
  26. writeln;
  27. {перестановка строк по возрастанию элементов последнего столбца}
  28. for i:=1 to m-1 do
  29. for k:=i+1 to m do
  30. if a[i,n]>a[k,n] then
  31. for j:=1 to n do
  32.  begin
  33.   buf:=a[i,j];
  34.   a[i,j]:=a[k,j];
  35.   a[k,j]:=buf;
  36.  end;
  37. writeln('Строки по возрастанию последних элементов:');
  38. for i:=1 to m do
  39.  begin
  40.   for j:=1 to n do
  41.   write(a[i,j]:3);
  42.   writeln;
  43.  end;
  44. readln
  45. end.

Объяснение кода листинга программы

В данном коде используется язык программирования Turbo Pascal. Он содержит следующие переменные:

  • nmax: максимальное значение для строк и столбцов матрицы (константа).
  • a: матрица целых чисел размером (m x n), где m - количество строк, n - количество столбцов (динамичный массив).
  • m, n, i, j, k, imx: счетчики и индексы для перебора строк и столбцов матрицы.
  • buf: временная переменная для хранения значения элемента матрицы. Код начинается с инициализации переменной nmax и объявления переменных m, n, i, j, k, imx и buf. Затем происходит чтение значений m и n с помощью функции readln. Далее идет цикл, который повторяется до тех пор, пока m и n находятся в допустимых пределах (от 2 до nmax). Внутри цикла выводится сообщение с запросом количества строк и столбцов матрицы. После этого выводится исходный массив a с помощью цикла for. Внутри цикла выводится каждый элемент матрицы a[i,j]. Затем следует еще один цикл, который повторяется до тех пор, пока i меньше m-1. Внутри цикла происходит перестановка строк по возрастанию элементов последнего столбца. Для этого используется вложенный цикл for, который перебирает строки i и k. Если элемент a[i,n] больше элемента a[k,n], то происходит перестановка строк i и k. После завершения внутреннего цикла выводится сообщение с переставленными строками по возрастанию последних элементов. Наконец, выводится итоговый результат - матрица a с последними элементами, образующими возрастающую последовательность.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

9   голосов , оценка 3.667 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы