uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of integer;
n,i,j,l,k:byte;
sm,b:integer;
begin
clrscr;
randomize;
repeat
write('Размер матрицы до ',nmax,' n=');
readln(n);
until n in [1..nmax];
{вычисление сумм в строках и запись их в дополнительный столбец}
for i:=1 to n do
begin
sm:=0;
for j:=1 to n do
begin
a[i,j]:=random(10)-1;
if( a[i,j]>0)and(a[i,j] mod 2=0)
then sm:=sm+a[i,j];
end;
a[i,n+1]:=sm;
end;
writeln('Исходный массив:');
writeln('Сумма':(n*4+8));
for i:=1 to n do
begin
for j:=1 to n+1 do
if j=n+1 then write(a[i,j]:8)
else write(a[i,j]:4);
writeln;
end;
k:=0;
for j:=1 to n do
begin
l:=0;
for i:=1 to n do
if a[i,j]=0 then
begin
l:=1;
break;
end;
if l=0 then k:=k+1;
end;
writeln('Количество столбцов без нолей=',k);
{перестановка строк по неубыванию сумм(по последнему столбцу)}
for i:=1 to n-1 do
for l:=i+1 to n 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('Сумма':(n*4+8));
for i:=1 to n do
begin
for j:=1 to n+1 do
if j=n+1 then write(a[i,j]:8)
else write(a[i,j]:4);
writeln;
end;
readln
end.