Дана целочисленная квадратная матрица. Определить количество столбцов, не содержащих ни одного нулевого элемента. Характеристикой строки целочисленной матрицы назовём сумму её положительных чётных элементов. Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик — Pascal(Паскаль)

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.

Leave a Comment

20 − = 18