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

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

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

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

Задача 1#25909

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

Например для последовательности из шести элементов:

34;55;64;36;60;48;  Ответ: 1  144

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

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

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

# Функция для проверки пифагровой тройки
def pif(a, b, c):
    # Сортируем тройку по возрастанию,
    # чтобы наибольшее число стало третьим (гипотенузой)
    x, y, z = sorted((a, b, c))
    # Проверяем теорему Пифагора
    if z ** 2 == x ** 2 + y ** 2:
        return True
    else:
        return False


# Открываем файл
f = open("2__shvf.txt")
# Считываем все числа из файла
a = [int(x) for x in f]

# Получаем длину последовательности
n = len(a)
# Счётчик подходящих троек
c = 0
# Переменная максимальной суммы
# Очень маленькая, чтобы находить суммы больше
mx = -10 ** 10

# Перебираем все возможные тройки подряд идущих чисел
for i in range(n - 2):
    # Считаем сумму текущей тройки
    sm = a[i] + a[i + 1] + a[i + 2]

    # Проверяем на пифагорову тройку
    if pif(a[i], a[i + 1], a[i + 2]):
        # Увеличиваем счётчик подходящих троек
        c += 1
        # Обновляем максимальную сумму, если текущая больше
        mx = max(mx, sm)

print(c, mx)
                                                                                                     
                                                                                                     

Ответ: 24 240

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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