1) var a=array[1..10]of integer; i,max,poz: integer; begin writeln('vverite 10 elementov') for i:=1 to 10 do read(a[i]); max:=a[1]; poz:=1; for i:=2 to 10 do if (a[i]>max)then begin max:=a[i];poz:=i; end; writeln('max = ',max,' ego nomer =', poz); end. 2) var a=array[1..10]of integer; i:integer; begin writeln('vverite 10 elementov') for i:=1 to 10 do read(a[i]); for i:=1 to 10 do if (a[i]>=10)and(a[i]<=99) then writeln(a[i],' ego nomer',i); end. 3) var a=array[1..10]of integer; i,k,poz:integer; begin writeln('vverite 10 elementov') for i:=1 to 10 do read(a[i]); k:=0; for i:=10 downto 1 do begin if(a[i] mod 3 =0) then begin k:=k+1;poz:=i; end; if(k=2) then writeln(a[i],' ego nomer = ',i); end; if(k=0) then writeln('kratnyh 3 net'); if(k=1) then writeln('kratnyy 3 tol'ko 1: a[',poz,']=',a[poz]); end.
Из текста задания непонятно, нужен ли промежуточный вывод, поэтому он присутствует после каждого этапа, чтобы убедиться в правильности работы программы. Программа написана и отлажена в среде PascalABC.Net.
const n = 4; var a:array[1..n,1..n] of integer; i,j,s,amin,jmin,amax,imax: integer;
begin { инициализация массива } Writeln('Исходный массив'); for i:=1 to n do begin for j:=1 to n do begin a[i,j]:=Random(51)-25; { случайные числа на [-25;25] } Write(a[i,j]:4) end; Writeln end; { сумма элементов побочной диагонали } s:=0; for i:=1 to n do s:=s+a[n-i+1,i]; Writeln('Сумма элементов побочной диагонали: ',s); Writeln('Меняем местами первый и последний столбцы'); for i:=1 to n do begin s:=a[i,1]; a[i,1]:=a[i,n]; a[i,n]:=s end; { вывод } for i:=1 to n do begin for j:=1 to n do Write(a[i,j]:4); Writeln end; { меняем местами минимальный элемент первой строки и максимальный элемент последнего столбца } amin:=a[1,1]; jmin:=1; for j:=2 to n do if amin>a[1,j] then begin amin:=a[1,j]; jmin:=j end; amax:=a[1,n]; imax:=1; for i:=2 to n do if amax<a[i,n] then begin amax:=a[i,n]; imax:=i end; a[1,jmin]:=amax; a[imax,n]:=amin; Writeln('Массив после обмена местами найденных элементов'); for i:=1 to n do begin for j:=1 to n do Write(a[i,j]:4); Writeln end end.
Тестовое решение: Исходный массив -14 -25 -14 -11 8 -5 5 0 5 20 -7 -9 -23 4 -3 18 Сумма элементов побочной диагонали: -9 Меняем местами первый и последний столбцы -11 -25 -14 -14 0 -5 5 8 -9 20 -7 5 18 4 -3 -23 Массив после обмена местами найденных элементов -11 8 -14 -14 0 -5 5 -25 -9 20 -7 5 18 4 -3 -23
var a=array[1..10]of integer;
i,max,poz: integer;
begin
writeln('vverite 10 elementov')
for i:=1 to 10 do
read(a[i]);
max:=a[1];
poz:=1;
for i:=2 to 10 do
if (a[i]>max)then begin max:=a[i];poz:=i; end;
writeln('max = ',max,' ego nomer =', poz);
end.
2)
var a=array[1..10]of integer;
i:integer;
begin
writeln('vverite 10 elementov')
for i:=1 to 10 do
read(a[i]);
for i:=1 to 10 do
if (a[i]>=10)and(a[i]<=99) then writeln(a[i],' ego nomer',i);
end.
3)
var a=array[1..10]of integer;
i,k,poz:integer;
begin
writeln('vverite 10 elementov')
for i:=1 to 10 do
read(a[i]);
k:=0;
for i:=10 downto 1 do
begin
if(a[i] mod 3 =0) then begin k:=k+1;poz:=i; end;
if(k=2) then writeln(a[i],' ego nomer = ',i);
end;
if(k=0) then writeln('kratnyh 3 net');
if(k=1) then writeln('kratnyy 3 tol'ko 1: a[',poz,']=',a[poz]);
end.
Программа написана и отлажена в среде PascalABC.Net.
const
n = 4;
var
a:array[1..n,1..n] of integer;
i,j,s,amin,jmin,amax,imax: integer;
begin
{ инициализация массива }
Writeln('Исходный массив');
for i:=1 to n do
begin
for j:=1 to n do
begin
a[i,j]:=Random(51)-25; { случайные числа на [-25;25] }
Write(a[i,j]:4)
end;
Writeln
end;
{ сумма элементов побочной диагонали }
s:=0;
for i:=1 to n do s:=s+a[n-i+1,i];
Writeln('Сумма элементов побочной диагонали: ',s);
Writeln('Меняем местами первый и последний столбцы');
for i:=1 to n do
begin s:=a[i,1]; a[i,1]:=a[i,n]; a[i,n]:=s end;
{ вывод }
for i:=1 to n do
begin
for j:=1 to n do Write(a[i,j]:4);
Writeln
end;
{ меняем местами минимальный элемент первой строки
и максимальный элемент последнего столбца }
amin:=a[1,1]; jmin:=1;
for j:=2 to n do
if amin>a[1,j] then begin amin:=a[1,j]; jmin:=j end;
amax:=a[1,n]; imax:=1;
for i:=2 to n do
if amax<a[i,n] then begin amax:=a[i,n]; imax:=i end;
a[1,jmin]:=amax; a[imax,n]:=amin;
Writeln('Массив после обмена местами найденных элементов');
for i:=1 to n do
begin
for j:=1 to n do Write(a[i,j]:4);
Writeln
end
end.
Тестовое решение:
Исходный массив
-14 -25 -14 -11
8 -5 5 0
5 20 -7 -9
-23 4 -3 18
Сумма элементов побочной диагонали: -9
Меняем местами первый и последний столбцы
-11 -25 -14 -14
0 -5 5 8
-9 20 -7 5
18 4 -3 -23
Массив после обмена местами найденных элементов
-11 8 -14 -14
0 -5 5 -25
-9 20 -7 5
18 4 -3 -23