Дана действительная матрица размера m*n; упорядочить строки матрицы по неубыванию значений наименьших элементов строк — Pascal(Паскаль)

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.

Leave a Comment

5 + 1 =