Дана матрица M*N. Поменять ее строки так, чтобы их минимальные элементы образовывали возрастающую последовательность — Pascal(Паскаль)

uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of real;
    n,m,i,j,l:byte;
    mn,b:real;
begin
clrscr;
randomize;
repeat
write('Количество строк до ',nmax,' m=');
readln(m);
until m in [1..nmax];
repeat
write('Количество столбцов до ',nmax,' n=');
readln(n);
until n in [1..nmax];
for i:=1 to m do
for j:=1 to n do
a[i,j]:=10*random;
{нахождение минимальных в строках и запись их в дополнительный столбец}
for i:=1 to m do
 begin
  mn:=a[i,1];
  for j:=1 to n do
  if a[i,j]<mn then mn:=a[i,j];
  a[i,n+1]:=mn;
 end;
writeln('Исходный массив:');
writeln('Миним':(n*5+8));
for i:=1 to m do
 begin
  for j:=1 to n+1 do
  if j=n+1 then write(a[i,j]:8:1)
  else write(a[i,j]:5:1);
  writeln;
 end;
writeln;
{перестановка строк по неубыванию сумм(по последнему столбцу)}
for i:=1 to m-1 do
for l:=i+1 to m do
if a[i,n+1]>a[l,n+1] then
for j:=1 to n+1 do
 begin
  b:=a[i,j];
  a[i,j]:=a[l,j];
  a[l,j]:=b;
 end;
writeln('Строки по неубыванию минимумов:');
writeln('Миним':(n*5+8));
for i:=1 to m do
 begin
  for j:=1 to n+1 do
  if j=n+1 then write(a[i,j]:8:1)
  else write(a[i,j]:5:1);
  writeln;
 end;
readln
end.

Leave a Comment

36 − = 34