На вход программы поступает последовательность из N натуральных чисел. Рассматриваются все пары различных элементов последовательности, у которых различные остатки от деления на d = 160 и хотя бы одно из чисел делится на p = 7. Среди таких пар, необходимо найти и вывести пару с максимальной суммой элементов.
Описание входных и выходных данных.
В первой строке входных данных задаётся количество чисел N (1 ≤ N ≤ 1000). В каждой из последующих N строк записано одно натуральное число, не превышающее 10000. В качестве результата программа должна напечатать элементы искомой пары. Если среди найденных пар максимальную сумму имеют несколько, то можно напечатать любую из них. Если таких пар нет, то вывести два нуля.
Пример входных данных:
4
168
7
320
328
Пример выходных данных для приведённого выше примера входных данных:
168 320
Пояснение: Из 4 чисел можно составить 6 пар. В данном случае условиям удовлетворяют пары: 168 и 320, 168 и 7, 320 и 7, 328 и 7. Максимальную сумму дает пара 168 и 320.
Требуется написать эффективную по времени и по памяти программу для решения описанной задачи. Программа считается эффективной по времени, если при увеличении количества исходных чисел N в k раз время работы программы увеличивается не более чем в k раз. Программа считается эффективной по памяти, если память, необходимая для хранения всех переменных программы, не превышает 1 Кбайт и не увеличивается с ростом N.
Максимальная оценка за правильную (не содержащую синтаксических ошибок и дающую правильный ответ при любых допустимых входных данных) программу, эффективную по времени и по памяти, — 4 балла. Максимальная оценка за правильную программу, эффективную только по времени — 3 балла. Максимальная оценка за правильную программу, не удовлетворяющую требованиям эффективности, — 2 балла. Вы можете сдать одну программу или две программы решения задачи (например, одна из программ может быть менее эффективна). Если Вы сдадите две программы, то каждая из них будет оцениваться независимо от другой, итоговой станет бо́льшая из двух оценок.
Перед текстом программы обязательно кратко опишите алгоритм решения. Укажите используемый язык программирования и его версию.
Отметим:
m71 самое большое число кратное 7;
m72 второе по величине число кратное 7 и остаток от деления на 160 не равен остатку от деления m71 на 160;
m1 самое большое число не кратное 7;
m2 второе по величине число не кратное 7 и остаток от деления на 160 не равен остатку от деления m71 на 160.
Пример 1. Программа на языке Паскаль. Программа эффективна по времени и памяти.
var
n, i, m71, m72, m1, m2, max1, max2, x: integer;
begin
readln(N);
m71:=0;
m72:=0;
m1:=0;
m2:=0;
max1:=0;
max2:=0;
for i:= 1 to n do begin
readln(x);
if (x mod 7 = 0) and (x mod 160 = m71 mod 160) and (x > m71) then
m71 := x
else if (x mod 7 = 0) and (x mod 160 <> m71 mod 160) and (x > m71) then
begin
m72 := m71;
m71 := x;
end
else if (x mod 7 = 0) and (x mod 160 <> m71 mod 160) and (x > m72) then
m72 := x
else if (x mod 7 <> 0) and (x mod 160 = m1 mod 160) and (x > m1) then
m1 := x
else if (x mod 7 <> 0) and (x mod 160 <> m1 mod 160) and (x > m1) then
begin
m2 := m1;
m1 := x;
end
else if (x mod 7 <> 0) and (x mod 160 <> m1 mod 160) and (x > m2) then
m2 := x;
end;
if (m71 = 0) and (m72 = 0) then
writeln(0, ' ', 0)
else if (m72 = 0) and (m2 = 0) and (m71 mod 160 = m1 mod 160) then
writeln(0, ' ', 0)
else
begin
if (m71+m72)>(max1+max2) then
begin
max1 := m71;
max2 := m72;
end;
if ((m71+m1)>(max1+max2)) and (m71 mod 160 <> m1 mod 160) then
begin
max1 := m71;
max2 := m1;
end;
if ((m71+m2)>(max1+max2)) and (m71 mod 160 <> m2 mod 160) then
begin
max1 := m71;
max2 := m2;
end;
if (((m72 + m1) > (max1 + max2)) and ((m72 mod 160) <> (m1 mod 160))) then
begin
max1 := m72;
max2 := m1;
end;
writeln(max1, ' ', max2);
end;
end.
Пример 2. Программа на языке Python 3. Программа эффективна по времени и памяти.
n = int(input())
m71=0
m72=0
m1=0
m2=0
max1=0
max2=0
for i in range (n):
x = int(input())
if (x % 7 == 0) and (x % 160 == m71 % 160) and (x > m71):
m71 = x
elif (x % 7 == 0) and (x % 160 != m71 % 160) and (x > m71):
m72 = m71
m71 = x
elif (x % 7 == 0) and (x % 160 != m71 % 160) and (x > m72):
m72 = x
elif (x % 7 != 0) and (x % 160 == m1 % 160) and (x > m1):
m1 = x
elif (x % 7 != 0) and (x % 160 != m1 % 160) and (x > m1):
m2 = m1
m1 = x
elif (x % 7 != 0) and (x % 160 != m1 % 160) and (x > m2):
m2 = x
if (m71 == 0) and (m72 == 0):
print(0,0)
elif (m72 == 0) and (m2 == 0) and (m71 % 160 == m1 % 160):
print(0,0)
else:
if (m71+m72)>(max1+max2):
max1 = m71
max2 = m72
if (m71+m1)>(max1+max2) and (m71 % 160 != m1 % 160):
max1 = m71
max2 = m1
if (m71+m2)>(max1+max2) and (m71 % 160 != m2 % 160):
max1 = m71
max2 = m2
print(max1,max2)

