В целочисленной квадратной матрице нужно определить: сумму элементов в тех строках, которые не содержат отрицательных элементов; максимум среди сумм элементов диагоналей, параллельных главной диагонали — Pascal(Паскаль)

uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax]of integer;
    n,i,j,c,sum,k,max,l,p:integer;
begin
clrscr;
repeat
write('Размер матрицы до ',nmax,' n= ');
readln(n);
until n in [1..nmax];
randomize;
writeln('Матрица:');
for i:=1 to n do
 begin
  for j:=1 to n  do
   begin
    a[i,j]:=random(10)-1;
    write(a[i,j]:4);
   end;
  writeln;
 end;
writeln('Суммы в тех строках, которые не содержат отрицательных элементов:');
l:=0;
for i:=1 to n do
 begin
  sum:=0;k:=0;
  for j:=1 to n do
  if a[i,j]<0 then k:=1;
  if k=0 then
   begin
    l:=1;
    for j:=1 to n do
    sum:=sum+a[i,j];
    writeln('Сумма в строке ',i,' =',sum);
   end;
 end;
if l=0 then writeln('Строк без отрицательных элементов нет!');
write('Нажмите Enter...');
readln;
writeln('Суммы элементов на диагоналях, параллельных главной:');
max:=a[n,1];
for l:=1 to 2*n-1 do
 begin
  sum:=0;
  if l<n then{если нужна и сама главная, то l<=n}
   begin
    for i:=n-l+1 to n do
    for j:=1 to l do
    if j=i-n+l then sum:=sum+a[i,j];
    writeln('Сумма ',l:2,'=',sum:3);
    if sum>max then max:=sum;
   end
  else if l>n then
   begin
    for i:=1 to 2*n-l do
    for j:=l-n+1 to n do
    if j=i+l-n then sum:=sum+a[i,j];
    writeln('Сумма ',l:2,'=',sum:3);
    if sum>max then max:=sum;
   end;
 end;
writeln('Максимальная сумма=',max);
readln
end.

Leave a Comment

7 + 2 =