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

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

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

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

Задача 1#61007

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

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

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

Напишем программу, которая будет проверять все пары соседних элементов последовательности. Нужно найти пары, в которых ровно одно число заканчивается на 3. Для этого в условии используется выражение, которое проверяет для каждого из двух чисел, заканчивается ли оно на 3: если оно заканчивается — выражение (abs(число)

Дальше программа считает сумму квадратов этих двух чисел и сравнивает с квадратом максимального числа из всей последовательности, которое тоже заканчивается на 3. Если сумма квадратов пары больше либо равна этому значению, пара считается подходящей. При этом программа считает количество таких пар и сохраняет максимальную из сумм квадратов.

# открываем файл с числами
f = open("17.txt")

# считываем все числа из файла в список
a = [int(i) for i in f.readlines()]

# находим максимальный элемент, оканчивающийся на 3 (учитываем абсолютное значение, чтобы правильно обрабатывать отрицательные числа)
maxe3 = -100000000000
for i in range(len(a)):
    if abs(a[i]) % 10 == 3:
        maxe3 = max(maxe3, a[i])

# переменные для подсчёта подходящих пар и максимальной суммы квадратов
count = 0
maxs = 0

# перебираем все пары соседних элементов
for i in range(len(a) - 1):
    # проверяем, что ровно одно число заканчивается на 3
    # выражение (abs(a[i]) % 10 == 3) и (abs(a[i+1]) % 10 == 3) даёт True или False,
    # которые в арифметическом контексте равны 1 или 0, их сумма равна 1 только если ровно одно из чисел заканчивается на 3
    if (abs(a[i]) % 10 == 3) + (abs(a[i + 1]) % 10 == 3) == 1:
        # проверяем, что сумма квадратов пары не меньше квадрата максимального числа, оканчивающегося на 3
        if a[i] ** 2 + a[i + 1] ** 2 >= maxe3 ** 2:
            count += 1
            maxs = max(maxs, a[i] ** 2 + a[i + 1] ** 2)

# выводим количество подходящих пар и максимальную сумму квадратов
print(count, maxs)

Ответ: 180 190360573

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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