uses crt;
const nmax=20;
type matr=array[1..nmax,1..nmax] of integer;
procedure Pov90(var a:matr;n:byte);
var i,p,k:byte;
x:integer;
begin
p := n div 2;
for i:=1 to p do
for k:=i to n-i do
begin
x:=a[i,k];
a[i,k]:=a[n-k+1,i];
a[n-k+1,i]:=a[n-i+1,n-k+1];
a[n-i+1,n-k+1]:=a[k,n-i+1];
a[k,n-i+1]:=x;
end;
end;
var a:matr;
xn,xk:integer;
n,i,k:byte;
begin
clrscr;
randomize;
repeat
write('Размер матрицы до ',nmax,' n=');
readln(n);
until n in [1..nmax];
repeat
writeln('Введите нижний и верхний пределы диапазона чисел:');
readln(xn,xk);
until xn<xk;
writeln('Исходная матрица:');
for i:=1 to n do
begin
for k:=1 to n do
begin
a[i,k]:=random(xk-xn+1)+xn;
write(a[i,k]:5);
end;
writeln;
end;
writeln;
Pov90(a,n);
writeln('Поворот на 90 градусов по часовой стрелке:');
for i:=1 to n do
begin
for k:=1 to n do
write(a[i,k]:5);
writeln;
end;
readln
end.