uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of real;
b:array[1..nmax] of real;
c:array[1..nmax] of byte;
m,n,i,j,k:byte;
mn,mx,p:real;
begin
clrscr;
randomize;
repeat
write('Количество строк до ',nmax,' n=');
readln(n);
until n in [1..nmax];
repeat
write('Количество столбцов до ',nmax,' m=');
readln(m);
until m in [1..nmax];
writeln('Исходная матрица:');
for k:=1 to n do
begin
for j:=1 to m do
begin
a[k,j]:=9*random-4;
write(a[k,j]:5:2);
end;
writeln;
end;
writeln;
for k:=1 to n do
begin
mx:=a[k,1];
for j:=1 to m do
if a[k,j]>mx then mx:=a[k,j];
b[k]:=mx;
end;
writeln('Массив максимальных в строках:');
for i:=1 to n do
write(b[i]:0:2,' ');
writeln;
for k:=1 to n do
begin
mx:=a[k,1];mn:=a[k,1];
for j:=1 to m do
if a[k,j]>mx then mx:=a[k,j]
else if a[k,j]<mn then mn:=a[k,j];
b[k]:=mx+mn;
end;
writeln('Массив сумм максимальных и минимальных в строках:');
for i:=1 to n do
write(b[i]:0:2,' ');
writeln;
for k:=1 to n do
begin
i:=0;
for j:=1 to m do
if a[k,j]<0 then i:=i+1;
c[k]:=i;
end;
writeln('Массив количеств отрицательных в строках:');
for i:=1 to n do
write(c[i],' ');
writeln;
for k:=1 to n do
begin
p:=1;i:=0;
for j:=1 to m do
if(abs(a[k,j])>=1)and(abs(a[k,j])<=1.5) then
begin
i:=1;
p:=p*a[k,j];
end;
if i=0 then b[k]:=0
else b[k]:=p;
end;
writeln('Массив произведений элементов инт.[1,1.5] в строках:');
for i:=1 to n do
write(b[i]:0:2,' ');
readln
end.