Задание 17. Информатика. 2023-14

Просмотры: 68
Изменено: 24 ноября 2024

В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые значения от \(-10~000\) до \(10~000\) включительно. Определите и запишите в ответе сначала количество пар элементов последовательности, в которых сумма элементов не менее \(50\) и оба числа в паре неотрицательные, затем минимальное из произведений элементов таких пар. В данной задаче под парой подразумевается два идущих подряд элемента последовательности.

Файл с данными

Решение:

Python


def sum_ge_50(t: tuple[int]) -> bool:
    return sum(t) >= 50 and all(x >= 0 for x in t)

file_desc = open('17var14.txt')
num_array = [int(x) for x in file_desc.readlines()]

final_tuple = tuple(filter(sum_ge_50, zip(num_array, num_array[1:])))
min_prod = min(map(lambda f: f[0]*f[1], final_tuple))

print(len(final_tuple), min_prod)

Ответ: \(1042 \,\, 6736\)