Array68. Дан массив размера $$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 |
program Array68; uses SysUtils; var a : array[1..10] of integer; N,Amin,Amax,i:Integer; begin Write('N: '); Readln(N); Writeln('A: '); for i:=1 to N do begin write(i,' :'); readln(a[i]); end; Amax:=1; for i:=1 to N do if a[Amax]<a[i] then Amax:=i; Amin:=Amax; for i:=1 to N do if a[Amin]>a[i] then Amin:=i; i:=a[Amax]; a[Amax]:=a[Amin]; a[Amin]:=i; for i:=1 to N do writeln(i,' :',a[i]); end. |
Задачи из раздела Array можно посмотреть здесь.
А если минимальный и максимальный элементы массива не уникальны, тогда менять все на все или первый на первый, или… догадайся сама, короче.