Дана последовательность N целых положительных чисел. Необходимо определить количество пар элементов этой последовательности, сумма которых делится на m = 60 и при этом хотя бы один элемент из пары больше b = 40. Описание входных и выходных данных.

В первой строке входных данных задаётся количество чисел N (2 ≤ N ≤ 10 000). В каждой из последующих N строк записано одно натуральное число, не превышающее 10 000.

Пример входных данных:

6

30

30

150

20

40

100

Пример выходных данных для приведённого выше примера входных данных:

3

Пояснение. Из данных шести чисел можно составить три пары, удовлетворяющие условию: (30, 150), (30, 150), (20, 100). У пар (30, 30) и (20, 40) сумма делится на 60, но оба элемента в этих парах не превышают 40.

Требуется написать эффективную по времени и по памяти программу для решения описанной задачи. Программа считается эффективной по времени, если при увеличении количества исходных чисел N в k раз время работы программы увеличивается не более чем в k раз. Программа считается эффективной по памяти, если память, необходимая для хранения всех переменных программы, не превышает 1 Кбайт и не увеличивается с ростом N.

Максимальная оценка за правильную (не содержащую синтаксических ошибок и дающую правильный ответ при любых допустимых входных данных) программу, эффективную по времени и по памяти, — Максимальная оценка за правильную программу, эффективную только по времени — Максимальная оценка за правильную программу, не удовлетворяющую требованиям эффективности, — Вы можете сдать одну программу или две программы решения задачи (например, одна из программ может быть менее эффективна). Если Вы сдадите две программы, то каждая из них будет оцениваться независимо от другой, итоговой станет бо́льшая из двух оценок.

Перед текстом программы обязательно кратко опишите алгоритм решения. Укажите используемый язык программирования и его версию.

НУЖНО НА ЯЗЫКЕ C++

dppfpffpfp dppfpffpfp    1   13.09.2020 15:51    4

Ответы
yl800845 yl800845  15.10.2020 20:49

#include <iostream>

using namespace std;

signed main() {

  int n;

  cin >> n;

  int a[n];

  for(int i = 0; i < n; i++)

      cin >> a[i];

  int cnt = 0;

  for(int i = 0; i < n; i++)

      for(int j = i+1; j < n; j++)

          if((a[i] - a[j]) % 80 == 0 && max(a[i],a[j]) > 100)

              cnt++;

  cout << cnt;

}

ПОКАЗАТЬ ОТВЕТЫ
Другие вопросы по теме Информатика