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.