Отсортировать элементы квадратной вещественной матрицы размерности n, стоящие на побочной диагонали, применив сортировку бинарным включением — Pascal(Паскаль)

uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of real;
    n,i,j,l,r,m:byte;
    x:real;
begin
clrscr;
repeat
write('Размер матрицы до ',nmax,' n=');
readln(n);
until n in [1..nmax];
writeln('Исходная матрица:');
for i:=1 to n do
 begin
   for j:=1 to n do
    begin
     a[i,j]:=10*random;
     write(a[i,j]:5:1);
    end;
   writeln;
 end;
writeln;
for i:=2 to n do
 begin
  x:=a[i,n-i+1];
  l:=1;
  r:=i-1;
  while l<=r do
   begin
    m:=(l+r) div 2;
    if x<a[m,n-m+1] then r:=m-1 else l:=m+1
   end;
  for j:=i-1 downto l do a[j+1,n-j]:=a[j,n-j+1];
  a[l,n-l+1]:=x
 end; { Окончание алгоритма сортировки бинарными включениями }
writeln('Сортировка побочной диагонали:');
for i:=1 to n do
 begin
  for j:=1 to n do
  write(a[i,j]:5:1);
  writeln;
 end;
readln
end.

Leave a Comment

6 + 1 =