Является ли последовательность элементов массива упорядоченной по убыванию при просмотре его от левого верхнего угла. Если нет — напечатать индексы элемента, нарушающего последовательность- Pascal(Паскаль)

uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax] of integer;
    m,n,i,j,inp,jnp:byte;
    f:boolean;
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 i:=1 to n do
for j:=1 to m do
 begin
  write('a[',i,',',j,']=');
  readln(a[i,j]);
 end;
clrscr;
writeln('Исходная матрица:');
for i:=1 to n do
 begin
   for j:=1 to m do
   write(a[i,j]:4);
   writeln;
 end;
writeln;
f:=true;
i:=1;j:=1;
while (i<=n)and f do
 begin
  while (j<=m)and f do
  if((j>1)and(a[i,j]>=a[i,j-1]))
  or((i>1)and(a[i,1]>=a[i-1,m]))then
   begin
    f:=false;
    inp:=i;
    jnp:=j;
   end
  else j:=j+1;
  if j>m then
   begin
    i:=i+1;
    j:=1;
   end;
 end;
if f then write('Все элементы упорядочены по убыванию')
else write('Индексы нарушающих порядок [',inp,',',jnp,']');
readln
end.

Leave a Comment

− 5 = 3