uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of integer;
b:array[1..nmax] of integer;
n,i,j,imx:byte;
mx:integer;
begin
clrscr;
randomize;
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]:=random(50)-25;
write(a[i,j]:5);
end;
writeln;
end;
writeln;
writeln('Вектор последовательных сумм элементов главной диагонали:');
imx:=0;mx:=a[n,n];
for i:=1 to n do
begin
b[i]:=0;
for j:=i to n do
b[i]:=b[i]+a[j,j];
write(b[i],' ');
if b[i]>mx then
begin
mx:=b[i];
imx:=i;
end;
end;
writeln;
write('Максимальный элемент вектора b[',imx,']=',mx);
readln
end.