// PascalABC.NET 3.0, сборка 1128 procedure Convert(V:array of integer); begin for var i:=0 to V.Length-1 do if V[i]>9 then V[i]:=9 else if V[i]<5 then V[i]:=5 end;
procedure Develop(c:char; k:integer); begin WritelnFormat('*** Массив {0} ***',c); var a:=ArrRandom(k,-5,15); Write('исходный : '); a.PrintLn(','); Convert(a); Write('результат: '); a.PrintLn(','); end;
begin var m:=ReadInteger('Количество элементов в массиве A:'); var n:=ReadInteger('Количество элементов в массиве B:'); Develop('A',m); Develop('B',n) end.
Тестовое решение: Количество элементов в массиве A: 15 Количество элементов в массиве B: 10 *** Массив A *** исходный : 6,5,-5,9,1,0,-3,9,13,12,-4,8,11,14,-5 результат: 6,5,5,9,5,5,5,9,9,9,5,8,9,9,5 *** Массив B *** исходный : 5,12,12,4,7,9,7,-3,-1,-2 результат: 5,9,9,5,7,9,7,5,5,5
S: = 1
for i= 1 to 4 do
begin
A (i) = i
S = S*A(i)
end
S= S/i
Алгоритм подразумевает обработку с сохранением последнего указателя на i.
Проходя по циклу первый раз мы замечаем, что программа домножает результат S на число A (i), которое в свою очередь является равной своему индексу.
В самом теле цикла проходит следующая цепочка: S=1*1*2*3*4
Соответственно S=24
И поделив её на i, которое равно 4, мы получаем ответ 6.