Тема 27. Программирование

27.04 Пары/тройки чисел, выбрать из каждой, кратность

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

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

Задача 1#12327

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

Пример входного файла:

5

15  8

5  11

6  3

7  2

9  14

Ответ для данного примера: 53

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

Идея: соберем сумму из всех максимумов, если ее четность совпадает с четностью большинства, то все хорошо. Если нет, то может быть два случая - чисел какой-то четности намного больше, чем другой (>=3), либо количества отличаются на 1.

В первом случае достаточно сделать просто минимальную нечетную замену (в какой-то паре взять не максимальное число, а минимальное так, чтобы разность между числами в паре была минимальной нечетной из всех пар).

Во втором случае может так случиться, что при такой замене (для примера у нас сейчас четных на 1 больше, чем нечетных, а сумма нечетна) мы заменим одно четное четное на нечетное, теперь сумма стала четной, но нечетных стало больше. У нас есть два варианта - либо произведем одну замену нечет/чет, тогда четность суммы изменится, а баланс сохранится, либо произведем две замены чет/нечет, тогда баланс изменится, а четность суммы сохранится.

f = open(’15.txt’)
n = int(f.readline())

sMax = 0  # Максимальная сумма, которую можно собрать
count = [0, 0]  # Счетчик четных и нечетных чисел
md01 = 10000000000000000  # миндифф для пары чет/нечет
pmd01 = 10000000000000000  # предминдифф для пары чет/нечет
md10 = 10000000000000000  # миндифф для пары нечет/чет
pmd10 = 10000000000000000  # предминдифф для пары нечет/чет

for i in range(n):
    x, y = map(int, f.readline().split())
    sMax += max(x, y)
    count[max(x, y) % 2] += 1
    diff = max(x, y) - min(x, y)
    if diff % 2 == 1:
        # Соберем мин разности для конкретных замен нечет/чет и чет/нечет
        if max(x, y) % 2 == 1:
            if diff < md10:
                pmd10 = md10
                md10 = diff
            elif diff < pmd10:
                pmd10 = diff
        else:
            if diff < md01:
                pmd01 = md01
                md01 = diff
            elif diff < pmd01:
                pmd01 = diff

if count[sMax % 2] == max(count):
    print(sMax)
elif max(count) - min(count) == 1:
    if max(count) == count[0]:
        print(sMax - min(md10, md01 + pmd01))
    else:
        print(sMax - min(md01, md10 + pmd10))
else:
                                                                                                     
                                                                                                     
    if max(count) == count[0]:
        print(sMax - min(md10, md01))
    else:
        print(sMax - min(md10, md01))

Ответ: 36898658

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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