Тема 17. Обработка числовой последовательности

17.01 Обработка пар элементов последовательности

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела обработка числовой последовательности
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#52525

В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые значения от 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="")

Ответ: 28862085

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

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

Бесплатное онлайн-обучение

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

Налоговые вычеты

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

Специальное предложение
для учителей

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

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!