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