Matrix49. Дана матрица размера $$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 |
program Matrix49; type matrix = array [1..10,1..10] of integer; var a:matrix; Min, Max, M, N, i, j, K1, K2:Integer; procedure Swap(var X,Y:Integer); begin if x<>y then begin X:=X+Y; Y:=X-Y; X:=X-Y; end; 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 begin Max:=1; Min:=1; for j:=2 to N do begin if a[i,j]>a[i,Max] then Max:=j; if a[i,j]<a[i,Min] then Min:=j; end; Swap(a[i,Max],a[i,Min]); end; for i:=1 to M do begin for j:=1 to N do begin Write(' : ',a[i,j]); end; writeln(' : '); end; end. |
Другие задачи из раздела Matrix можно посмотреть здесь.
В вашей программе меняются местами только первый максимум и первый минимум. Вы не учли, что максимумов и минимумов в строке может быть больше чем по одному.
Зачем описывать процедуру Swap, если в паскале есть встроенная swap?
В borland pascal нет процедуры Swap. А если вы пользуетесь ABS паскаль, то да … наверно вам можно закоментить данную функцию…