Задание выполняется с использованием прилагаемых файлов.
Метеорологическая станция ведёт наблюдение за количеством выпавших осадков. Показания записываются каждую минуту в течении минут. Определеяется пара измерений, между которыми прошло не менее
минут. Найдите максимальную сумму показаний среди таких пар.
Входные данные:
Даны два входных файла(A и B), каждый из которых в первой строке содержит число — количество измерений, а также через пробел число
— минимальное количество минут между искомыми измерениями. В каждой из следующих
строк находится число: количество выпавших осадков.
Пример входных данных:
Для указанных входных данных ответом будет .
В ответ укажите два числа через пробел: сначала искомое значение для файла A, затем для файла B.
Переборное решение:
f = open(’26_A.txt’)
n, s = map(int, f.readline().split())
a = [int(i) for i in f]
mx = -10 ** 10
for i in range(n):
for j in range(i + 1, n):
if j - i >= s:
mx = max(mx, a[i] + a[j])
print(mx)
Эффективное решение:
f = open(’26_B.txt’)
n, s = map(int, f.readline().split())
a = [int(i) for i in f]
ans = -10 ** 10
s = 5 # Расстояние между элементами
# Максимальное найденное на данный момент число
mx_prev = -10 ** 10
for i in range(s, n):
# Обновляем предыдущий максимум
mx_prev = max(mx_prev, a[i - s])
# Обновляем ответ
ans = max(ans, a[i] + mx_prev)
print(ans)