17.01 Обработка пар элементов последовательности
Ошибка.
Попробуйте повторить позже
В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые значения от 0 до 10 000. Определите количество пар элементов последовательности, в которых хотя бы у одного из чисел сумма цифр троичной записи равна сумме цифр троичной записи максимального элемента последовательности, кратного 11. В ответе запишите количество найденных пар, затем минимальную из сумм элементов таких пар, числа записывайте без пробелов и разделителей. В данной задаче под парой подразумевается два идущих подряд элемента последовательности.
Решение программой.
Найдём максимальный элемент последовательности, кратный 11 (его остаток при делении на 11 равен 0), и вычислим сумму цифр его троичной записи. Затем пройдёмся по всем парам соседних элементов и проверим, что сумма цифр троичной записи хотя бы одного числа равна этой сумме. Для таких пар посчитаем количество и обновим минимальную сумму элементов пары.
# Функция для подсчёта суммы цифр в троичной записи def summ_three(number): summ = 0 x = number while x > 0: summ += x % 3 x //= 3 return summ # Открываем файл и считываем числа в список file = open(’17.txt’) arr = [int(_) for _ in file] # Инициализируем счётчик пар и минимум суммы counter_pairs = 0 min_summ = 10 ** 10 # Находим максимальный элемент, кратный 11 max_elem_11 = -10 ** 10 for elem in arr: if elem % 11 == 0: max_elem_11 = max(max_elem_11, elem) # Вычисляем сумму цифр троичной записи максимального элемента summ_three_max_elem_11 = summ_three(max_elem_11) # Проходим по всем соседним парам for index in range(len(arr) - 1): if summ_three(arr[index]) == summ_three_max_elem_11 \ or summ_three(arr[index + 1]) == summ_three_max_elem_11: counter_pairs += 1 min_summ = min(min_summ, arr[index] + arr[index + 1]) # Выводим количество пар и минимальную сумму без пробелов print(counter_pairs, min_summ, sep="")
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!