Matrix74. Дана матрица размера $$M \times N$$. Элемент матрицы называется ее локальным минимумом, если он меньше всех окружающих его элементов. Заменить все локальные минимумы данной матрицы на нули. При решении допускается использовать вспомогательную матрицу.
Решение:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
program Matrix74; type matrix = array [1..10,1..10] of integer; var a:matrix; K, M, N, i, j:Integer; Function CheckMatrixLocMin(var mat:matrix; X,Y:Integer):Boolean; Begin CheckMatrixLocMin:=true; if x>1 then if mat[x,y]>=mat[x-1,y] then CheckMatrixLocMin:=False; if x<M then if mat[x,y]>=mat[x+1,y] then CheckMatrixLocMin:=False; if y>1 then if mat[x,y]>=mat[x,y-1] then CheckMatrixLocMin:=False; if y<N then if mat[x,y]>=mat[x,y+1] then CheckMatrixLocMin:=False; if (y>1) and (x>1) then if mat[x,y]>=mat[x-1,y-1] then CheckMatrixLocMin:=False; if (y<N) and (x<M) then if mat[x,y]>=mat[x+1,y+1] then CheckMatrixLocMin:=False; if (y>1) and (x<M) then if mat[x,y]>=mat[x+1,y-1] then CheckMatrixLocMin:=False; if (y<N) and (x>1) then if mat[x,y]>=mat[x-1,y+1] then CheckMatrixLocMin:=False; end; begin Write('N: '); Readln(N); Write('M: '); Readln(M); for i:=1 to M do begin writeln(i,': '); for j:=1 to N do begin Write(j,' : '); Read(a[i,j]); end; end; for i:=1 to M do for j:=1 to N do if CheckMatrixLocMin(a,i,j) then a[i,j]:=0; for i:=1 to M do begin for j:=1 to N do begin Write(' : ',a[i,j]); end; writeln(' : '); end; end. |
Другие задачи из раздела Matrix можно посмотреть здесь.
не учитываются числа по диагоналям
вот такая функция должна быть если в один иф все условия запихать:
function locmin (a:matrix; i,j:integer): boolean;
begin
locmin:= false;
if ((i=1) or (a[i,j]<a[i-1,j])) and
((j=1) or(a[i,j]<a[i,j-1])) and
((i=m) or (a[i,j]<a[i+1,j])) and
((j=n) or(a[i,j]<a[i,j+1])) and
((j=n) or (i=m) or (a[i,j]<a[i+1,j+1])) and
((j=1) or (i=m) or (a[i,j]<a[i+1,j-1])) and
((j=n) or (i=1) or (a[i,j]<a[i-1,j+1])) and
((j=1) or (i=1) or (a[i,j]<a[i-1,j-1]))
then locmin:=true;
end;
Работает, но с условием, что элементы матрицы не отрицательные. Поэтому сразу на нули менять нельзя. Или менять на число меньшее минимального элемента, а потом вторым проходом менять на нули, или использовать вспомогательную матрицу.