1. Складіть програму,яка міняє місцями перший і найбільший елементи послідовності з 10 чисел.
2. Дано 20 дійсних чисел. Складіть програму для визначення, скільки з них більші за своїх "сусідів", тобто за попереднє та наступне числа.
3. У фігурному катанні загальна оцінка якості виконання елемента обчислюється за такими правилами: відкидаються найвища і найнижча оцінки, а з решти обчислюється середнє арифметичне. Складіть програму для визначення оцінки за цими правилами.
n := 7+9*((2570-35) div d + 1)
196 = 7+9*((2570-35) div d + 1)
(196-7)/9-1 = (2570-35) div d
20 = 2535 div d
4 = 507 div d
507/4 =126.75, значит можно взять меньше
подбором 126 125 124 123 122 121 => 6 чисел
или программой
//PascalABC.NET версия 3.2, сборка 1389
//Если программа не запускается, то обновите версию
function f(d: integer): integer;
var
n, s: integer;
begin
n := 7;
s := 35;
while s <= 2570 do
begin
s := s + d;
n := n + 9
end;
f := n;
end;
begin
for var i := 1 to 100000000 do
begin
if f(i) = 196 then writeln(i);
if f(i) <> 7 + 9 * ((2570 - 35) div i + 1) then writeln('not ', i);
end;
end.
X,P:array[1..100] of integer;
k,n:integer;
Begin
Write('Введите k: ');ReadLn(k);
Write('Введите массив X(',k,'): ');
For k:= 1 to k do
Read(X[k]);
Write('Массив P:');
n:=0;
For k:= 1 to k do
if X[k]<0 then
Begin
n:=n+1;
P[n]:=X[k];
End;
For k:= 1 to k do
if X[k]=0 then
Begin
n:=n+1;
P[n]:=X[k];
End;
For k:= 1 to k do
if X[k]>0 then
Begin
n:=n+1;
P[n]:=X[k];
End;
For k:= 1 to k do
Write(' ',P[k])
End.
Пример:
Введите k: 6
Введите массив X(6):3 0 -2 2 4 -3
Массив P: -2 -3 0 3 2 4