Регистрация
Войти
Стать экспертом Правила
Информатика

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

ОТВЕТЫ
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
#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;
}

63
Контакты
Реклама на сайте
Спрошу
О проекте
Новым пользователям
Новым экспертам