Param29. Описать процедуру SortCols($$A$$, $$M$$, $$N$$), выполняющую сортировку по возрастанию столбцов целочисленной матрицы $$A$$ размера $$M \times N$$ (столбцы сравниваются лексикографически: если первые элементы столбцов различны, то меньшим считается столбец, содержащий меньший первый элемент; если первые элементы столбцов равны, то анализируются их вторые элементы и т. д.). Двумерный массив $$A$$ является входным и выходным параметром. Используя процедуру SortCols, отсортировать столбцы данной матрицы $$A$$ размера $$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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
program Param29; type Matrix = array[1..10,1..10] of integer; var M,N,K,L:integer; A:Matrix; Procedure SwaP_Col(var A:Matrix; M,N,K1,K2:integer); var j:integer; begin for j:=1 to N do begin A[k1,j]:=A[k1,j]+A[k2,j]; A[k2,j]:=A[k1,j]-A[k2,j]; A[k1,j]:=A[k1,j]-A[k2,j]; end; end; Function Comparison_Col(A:Matrix; M,N,K1,K2:integer):boolean; var j:integer; begin j:=1; While (j<=N) do begin If A[k1,j]>A[k2,j] then begin Comparison_Col:=TRUE; break; end; If A[k1,j]<A[k2,j] then begin Comparison_Col:=FALSE; break; end; inc(j); end; if n=j then Comparison_Col:=FALSE; end; Procedure SortCols(var A:Matrix; M,N:integer); var Atemp:Matrix; k1,k2:integer; begin for k:=1 to M-1 do for k2:=1 to M-k do begin Writeln(k2,' - ',k2+1); if Comparison_Col(A,M,N,k2,k2+1) then begin Writeln(k2,' - ',k2+1); SwaP_Col(A,M,N,k2,k2+1); end; end; end; Procedure EnterMatrix(var B:Matrix; var M,N:integer); var j,j2:integer; begin Write('M: '); Readln(M); Write('N: '); Readln(N); for j:=1 to N do begin for j2:=1 to M do begin Write (' ',J2,':',J,' : '); Read (B[J2,J]); end; Writeln; end; end; Procedure InputMatrix(B:Matrix; M,N:integer); var j,j2:integer; begin Writeln('---'); Writeln(M,'x',N); for j:=1 to N do begin for j2:=1 to M do Write (B[J2,J],' '); Writeln; end; Writeln('---'); end; begin EnterMatrix(A,M,N); InputMatrix(A,M,N); SortCols(A,M,N); InputMatrix(A,M,N); end. |
Другие задачи из раздела Param можно посмотреть здесь.
Комментарии:
Комментарии 2