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

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

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

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

Задача 1#87450

В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые значения от 1 до 100 000 включительно. Определите количество пар в последовательности, в которых сумма чисел кратна 35 и ровно один элемент из пары - нечётный. В ответе через пробел запишите количество найденных пар, затем минимальную из сумм элементов таких пар. В данной задаче под парой подразумевается два идущих подряд элемента последовательности.

Вложения к задаче
Показать ответ и решение

Решение программой

Напишем программу, которая будет проверять все пары соседних чисел из файла, отбирая те, где сумма кратна 35 и ровно одно число нечётное. Для проверки первого условия будем находить остаток от деления на 35 суммы и сравнивать его с 0, если остаток равен 0, то сумма кратна 35. Для проверки второго условия будем сравнивать остатки от деления на 2 чисел пары, если они разные, то одно число четное, а другое нечетное, если одинаковые, то оба числа или четные или нечетные. Подходящие пары будем сохранять в отдельный список, чтобы после отработки цикла вывести их количество и минимальную сумму.

# Открываем файл ’17_L1.txt’ для чтения
f = open(’17_L1.txt’)
# Считываем все строки из файла и преобразуем их в целые числа, сохраняя в список ’a’
a = [int(i) for i in f]
# Создаем пустой список ’ans’ для хранения сумм подходящих пар
ans = []

# Перебираем все пары последовательных элементов списка ’a’
for i in range(len(a) - 1):
    # Проверяем, что сумма текущего и следующего элемента кратна 35
    # И ровно один из элементов пары нечётный (проверка через сравнение остатков от деления на 2)
    if (a[i] + a[i + 1]) % 35 == 0 and (a[i] % 2 != a[i + 1] % 2):
        # Если условия выполнены, добавляем сумму пары в список ’ans’
        ans += [a[i] + a[i + 1]]
print(len(ans), min(ans))

Ответ: 142 9415

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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