
Jomeena
7 год назад
Дана линейная таблица А[1: N], N < = 50. Каждый элемент A[i] с четным индексом заменить значением max(A[1], A[2],…,A[i]), а с нечетным - min(A[1], A[2],…,A[i]).
ОТВЕТЫ

Окунев
Jul 15, 2019
Const n=10;
var a:array[1..n] of integer;
max,min,i:integer;
begin
Randomize;
for i:=1 to n do begin
a[i]:=random(51);
write(a[i], );
end;
writeln;
max:=a[1];
min:=a[1];
for i:=1 to n do
begin
if a[i]gt;max then max:=a[i];
if a[i]lt;min then min:=a[i];
if i mod 2 = 1 then a[i]:=min else a[i]:=max;
end;
for i:=1 to n do write(a[i], );
writeln;
end.
Пример:
31 35 3 5 26 46 9 31 30 11
31 35 3 35 3 46 3 46 3 46
var a:array[1..n] of integer;
max,min,i:integer;
begin
Randomize;
for i:=1 to n do begin
a[i]:=random(51);
write(a[i], );
end;
writeln;
max:=a[1];
min:=a[1];
for i:=1 to n do
begin
if a[i]gt;max then max:=a[i];
if a[i]lt;min then min:=a[i];
if i mod 2 = 1 then a[i]:=min else a[i]:=max;
end;
for i:=1 to n do write(a[i], );
writeln;
end.
Пример:
31 35 3 5 26 46 9 31 30 11
31 35 3 35 3 46 3 46 3 46
#include lt;iostreamgt;
int GetMax(int n, int* A);
int GetMin(int n, int* A);
int main() {
std::cout lt;lt; "N=";
int N, i;
std::cin gt;gt; N;
int A[N+1];
// заполнение массива
for(i = 1; i lt;= N; i++) {
std::cout lt;lt; "A[" lt;lt; i lt;lt; "]=";
std::cin gt;gt; A[i];
}
// чётные индексы
for(i = 1; i lt;= N; i++) {
if (i 2 == 0) {
A[i] = GetMax(i, A);
}
}
// нечётные индексы
for(i = 1; i lt;= N; i++) {
if (i 2 == 1) {
A[i] = GetMin(i, A);
}
}
std::cout lt;lt; "Результат:" lt;lt; \n;
for(i = 1; i lt;= N; i++)
std::cout lt;lt; A[i] lt;lt; ;
return 0;
}
int GetMax(int n, int* A) {
int max = A[1];
for(int i = 1; i lt;= n; i++)
if (A[i] gt; max)
max = A[i];
return max;
}
int GetMin(int n, int* A) {
int min = A[1];
for(int i = 1; i lt;= n; i++)
if (A[i] lt; min)
min = A[i];
return min;
}
int GetMax(int n, int* A);
int GetMin(int n, int* A);
int main() {
std::cout lt;lt; "N=";
int N, i;
std::cin gt;gt; N;
int A[N+1];
// заполнение массива
for(i = 1; i lt;= N; i++) {
std::cout lt;lt; "A[" lt;lt; i lt;lt; "]=";
std::cin gt;gt; A[i];
}
// чётные индексы
for(i = 1; i lt;= N; i++) {
if (i 2 == 0) {
A[i] = GetMax(i, A);
}
}
// нечётные индексы
for(i = 1; i lt;= N; i++) {
if (i 2 == 1) {
A[i] = GetMin(i, A);
}
}
std::cout lt;lt; "Результат:" lt;lt; \n;
for(i = 1; i lt;= N; i++)
std::cout lt;lt; A[i] lt;lt; ;
return 0;
}
int GetMax(int n, int* A) {
int max = A[1];
for(int i = 1; i lt;= n; i++)
if (A[i] gt; max)
max = A[i];
return max;
}
int GetMin(int n, int* A) {
int min = A[1];
for(int i = 1; i lt;= n; i++)
if (A[i] lt; min)
min = A[i];
return min;
}
63