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

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

Задача 1#61579

Задание выполняется с использованием прилагаемых файлов.

Метеорологическая станция ведёт наблюдение за количеством выпавших осадков. Показания записываются каждую минуту в течении N  минут. Определеяется пара измерений, между которыми прошло не менее K  минут. Найдите максимальную сумму показаний среди таких пар.

Входные данные:

Даны два входных файла(A и B), каждый из которых в первой строке содержит число N  - количество измерений, а также через пробел число K  - минимальное количество минут между искомыми измерениями. В каждой из следующих N  строк находится число: количество выпавших осадков.

Пример входных данных:

6 2

10

1

15

30

1515

3

Для указанных входных данных ответом будет 1530  .

В ответе укажите одно число: значение искомой величины для файла А. Файл Б для тех кто хочет проверить свои знания, ответ: 174980.

Вложения к задаче
Показать ответ и решение
def neeff(a, k): # Неэффективный алгоритм
    m = -10**9
    n = len(a)
    for i in range(n):
        for j in range(i + k, n):
            m = max(m, a[i] + a[j])
    return m


def eff(a, k): # Эффективный
    m = -10**9
    n = len(a)
    maxim = -10**20
    for i in range(k - 1, n):
        m = max(m, a[i] + maxim)
        # a[i - (k - 1)] --> свалку
        maxim = max(maxim, a[i - (k - 1)])
    return m

def eff_stat(a, k): # Эффективный статический
    b = []
    m = -10**9
    n = len(a)
    for i in range(n):
        b.append((a[i], i))
    b.sort()
    if len(b) >= 100:
        c = b[-100:]
    else:
        c = b.copy()
    for x in range(len(c)):
        for y in range(x + 1, len(c)):
            if abs(c[x][1] - c[y][1]) >= k:
                m = max(m, c[x][0] + c[y][0])
    return m

f = open(’Задача_27.txt’)
n, k = [int(s) for s in f.readline().split()]
a = [int(s) for s in f]
                                                                                                     
                                                                                                     
print(eff(a, k))

Ответ: 179

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

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

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

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

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

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

Бесплатное обучение
в Школково

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

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

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

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

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

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

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

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