Алгоритм Ввод массива A[n,m] Max := A[1,1]; k := 1; p := 1; s := 0; Алгоритм Ввод массива A[n,m] Max := A[1,1]; k := 1; p := 1; c := 0; Цикл по i от 1 до n (по строкам) Цикл по j от 1 до m (по столбцам) Если (A(i, j) = Max) and ((i<>k) or (j<>p)) То c := c+1; Если (A(i, j) > Max) То k := i; p := j; c := 1; Max: = A(i, j); Конец Если Конец цикла по столбцам Конец цикла по строкам Вывод "Элемент ", Max, " встречается ", c, " раз" Конец.
Программа var A: array of array of integer var i,j,m,n,k,p,s,Max: integer BEGIN uses crt; clrscr; write ('Vvedite kol-vo strok: '); readln (n); write ('Vvedite kol-vo stolbtsov: '); readln (m); setlength(A,n,m); for i=1 to n do begin for j=1 to m do begin write ('Vvedite element vassiva: '); readln (A[i,j]); end; end; Max := A[1,1]; k := 1; p := 1; c := 0; for i=1 to n do begin for j=1 to m do begin if (A(i, j) = Max) and ((i<>k) or (j<>p)) then c := c+1; if (A(i, j) > Max) then begin k := i; p := j; c := 1; Max: = A(i, j); end; end; end; write ('Element ', Max, ' vstrechaetsya ', c, ' raz'); END.
Var input,output:text; n,i,j,g,nm,ans,t:integer; ara:array[0..1000] of integer; ar,arq:array[0..1000] of integer; ts,sum,a:integer; beginassign(input,'f.in');reset(input); assign(output,'f.out');rewrite(output); readln(input,a,n); ans:=10000; for i:=1 to n do begin read(input,ar[i]); ts:=ts+2*ar[i]; end; if ts<a then writeln(output,'-1') else begin ara[1]:=3;for i:=2 to 15 do begin ara[i]:=3*ara[i-1]; end; for i:=1 to ara[n] do begin if arq[n]<2 then begin inc(arq[n]); sum:=sum+ar[n];inc(nm); end else begin g:=n;while arq[g]>1 do begin sum:=sum-ar[g]*arq[g];dec(nm,arq[g]);arq[g]:=0;dec(g); end; inc(arq[g]);sum:=sum+ar[g];inc(nm); end; if sum=a then begin if nm<ans then ans:=nm;end; end; if ans>1000 then writeln(output,'0') else writeln(output,ans); end; close(output);close(input);end.
Ввод массива A[n,m]
Max := A[1,1]; k := 1; p := 1; s := 0;
Алгоритм
Ввод массива A[n,m]
Max := A[1,1]; k := 1; p := 1; c := 0;
Цикл по i от 1 до n (по строкам)
Цикл по j от 1 до m (по столбцам)
Если (A(i, j) = Max) and ((i<>k) or (j<>p)) То c := c+1;
Если (A(i, j) > Max) То
k := i; p := j; c := 1;
Max: = A(i, j);
Конец Если
Конец цикла по столбцам
Конец цикла по строкам
Вывод "Элемент ", Max, " встречается ", c, " раз"
Конец.
Программа
var A: array of array of integer
var i,j,m,n,k,p,s,Max: integer
BEGIN
uses crt; clrscr;
write ('Vvedite kol-vo strok: '); readln (n);
write ('Vvedite kol-vo stolbtsov: '); readln (m);
setlength(A,n,m);
for i=1 to n do
begin
for j=1 to m do
begin
write ('Vvedite element vassiva: '); readln (A[i,j]);
end;
end;
Max := A[1,1]; k := 1; p := 1; c := 0;
for i=1 to n do
begin
for j=1 to m do
begin
if (A(i, j) = Max) and ((i<>k) or (j<>p)) then c := c+1;
if (A(i, j) > Max) then
begin
k := i; p := j; c := 1;
Max: = A(i, j);
end;
end;
end;
write ('Element ', Max, ' vstrechaetsya ', c, ' raz');
END.
input,output:text;
n,i,j,g,nm,ans,t:integer;
ara:array[0..1000] of integer;
ar,arq:array[0..1000] of integer;
ts,sum,a:integer;
beginassign(input,'f.in');reset(input);
assign(output,'f.out');rewrite(output);
readln(input,a,n);
ans:=10000;
for i:=1 to n do
begin
read(input,ar[i]);
ts:=ts+2*ar[i];
end;
if ts<a then writeln(output,'-1') else
begin
ara[1]:=3;for i:=2 to 15 do
begin
ara[i]:=3*ara[i-1];
end;
for i:=1 to ara[n] do
begin if arq[n]<2 then
begin inc(arq[n]);
sum:=sum+ar[n];inc(nm); end else
begin g:=n;while arq[g]>1 do
begin sum:=sum-ar[g]*arq[g];dec(nm,arq[g]);arq[g]:=0;dec(g);
end;
inc(arq[g]);sum:=sum+ar[g];inc(nm);
end;
if sum=a then
begin
if nm<ans then
ans:=nm;end;
end;
if ans>1000 then writeln(output,'0') else
writeln(output,ans); end;
close(output);close(input);end.