Param12. Описать процедуру SortIndex($$A$$, $$N$$, $$I$$), формирующую для вещественного массива $$A$$ размера $$N$$ индексный массив $$I$$. — массив целых чисел того же размера, содержащий номера элементов массива $$A$$ в том порядке, который соответствует возрастанию элементов массива $$A$$ (сам массив $$A$$ при этом не изменяется). Индексный массив $$I$$. является выходным параметром. С помощью этой процедуры создать индексные массивы для массивов $$A$$, $$B$$, $$C$$ размера $$N_A$$, $$N_B$$, $$N_C$$ соответственно.
Решение:
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 |
program Param12; type RArray = array[1..10] of Real; IArray = array[1..10] of Integer; var A,B,C:RArray; Na,Nb,Nc:integer; Ia,Ib,Ic:IArray; Procedure SortIndex(A:RArray; N:integer; var I:IArray); var k,k2:integer; begin for k:=1 to M do I[k]:=k; for k:=1 to N-1 do for k2:=1 to N-k do begin if A[I[k2]]>A[I[k2+1]] then begin I[k2]:=I[k2]+I[k2+1]; I[k2+1]:=I[k2]-I[k2+1]; I[k2]:=I[k2]-I[k2+1]; end; end; end; Procedure EnterArray(var A:RArray; var N:integer); var i:integer; begin Write('Size:'); Readln(N); for i:=1 to N do begin Write(i,': '); Readln(A[i]); end; end; Procedure InputArray(var A:IArray; var N:integer); var i:integer; begin Writeln('---'); for i:=1 to N do Writeln(i,': ',A[i]); Writeln('---'); end; begin EnterArray(A,Na); SortIndex(A,Na,Ia); InputArray(Ia,Na); EnterArray(B,Nb); SortIndex(B,Nb,Ib); InputArray(Ib,Nb); EnterArray(C,Nc); SortIndex(C,Nc,Ic); InputArray(Ic,Nc); end. |
Другие задачи из раздела Param можно посмотреть здесь.
Комментарии:
Комментарии 1