В файле содержится последовательность целых чисел.
Её элементы могут принимать целые значения от −100 000 до 100 000 включительно.
Определите количество пар последовательности, в которых элементы не равны, а абсолютное значение их разности делится на минимальный положительный элемент последовательности, кратный 33. Гарантируется, что такой элемент в последовательности есть.
В ответе запишите количество найденных пар, затем максимальную из сумм элементов таких пар.
В данной задаче под парой подразумевается два идущих подряд элемента последовательности.
Решение
🔹 Шаг 1. Считываем числа из файла
f = open("17.txt")
nums = [int(x) for x in f]
# 1. минимальный положительный элемент, кратный 33
min_33 = min(x for x in nums if x > 0 and x % 33 == 0)
count = 0
max_sum = 0
# 2. проверка пар соседних элементов
for i in range(len(nums) - 1):
a, b = nums[i], nums[i + 1]
if a != b and abs(a - b) % min_33 == 0:
count += 1
s = a + b
if s > max_sum:
max_sum = s
# 3. вывод результата
print(count, max_sum)
📌 Что происходит:
Теперь
nums — это вся числовая последовательность.
🔹 Шаг 2. Находим минимальный положительный элемент с нужным делителем
min_33 = min(x for x in nums if x > 0 and x % 33 == 0)
📌 Что происходит: перебираем все числа, оставляем положительные и кратные нужному делителю, выбираем минимальное. По условию такой элемент гарантированно есть.
🔹 Шаг 3. Подготавливаем переменные для подсчёта
count = 0
max_sum = 0
📌 Что означает:
count — количество подходящих пар (или троек);
max_sum / max_sq — лучший найденный результат (сумма или квадрат суммы), пока неизвестен.
🔹 Шаг 4. Проверяем пары соседних элементов
for i in range(len(nums) - 1):
a, b = nums[i], nums[i + 1]
if a != b and abs(a - b) % min_33 == 0:
count += 1
s = a + b
if s > max_sum:
max_sum = s
📌 Что происходит: перебираем соседние пары (nums[i], nums[i+1]), проверяем условие и обновляем count и максимальную сумму (или квадрат суммы).
🔹 Шаг 5. Выводим ответ
print(count, max_sum)
📌 Что выводим: сначала количество найденных пар (или троек), затем второе число из ответа по условию (для этого варианта: 33 164160).