Блог пользователя ilona

Автор ilona, 13 лет назад, По-русски

Сегодня, в 14.00, состоялась шестая командная олимпиада на neerc. Предлагаю здесь обсудить задачи.

  • Проголосовать: нравится
  • +12
  • Проголосовать: не нравится

»
13 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Кто-то знает как делать H без переборов и пропихов?

  • »
    »
    13 лет назад, # ^ |
      Проголосовать: нравится +3 Проголосовать: не нравится

    Сделаем двоичный поиск.

    Теперь нужно проверить, можно ли взять k человек из двудольного графа, чтобы между взятыми не было ребер. Это независимое множество. Известно, что независимое множество это дополнение вершинного покрытия. Нужно найти максимальное независимое множество -> минимальное вершинное покрытие. Мощность минимального вершинного покрытия в двудольном графе, как известно, равна максимальному паросочетанию.

    Нужно еще уметь восстанавливать ответ.

    • »
      »
      »
      13 лет назад, # ^ |
        Проголосовать: нравится 0 Проголосовать: не нравится

      Это делается, наподобие такого:
      Будем удалять по точке, и проверять что функция от оставшихся изменилась на нужную величину?

      • »
        »
        »
        »
        13 лет назад, # ^ |
        Rev. 2   Проголосовать: нравится 0 Проголосовать: не нравится

        Что именно? Поиск минимального вершинного покрытия?

        • »
          »
          »
          »
          »
          13 лет назад, # ^ |
          Rev. 2   Проголосовать: нравится 0 Проголосовать: не нравится

          Ой, восстановление ответа.

          • »
            »
            »
            »
            »
            »
            13 лет назад, # ^ |
              Проголосовать: нравится +5 Проголосовать: не нравится

            Например, можно так:

            Рассмотрим все вершины, в каждой доле вершины поделим на два типа: у которых есть пара и у которых нет.

            Теперь возьмем все вершины из левой доли, у которых нет пары. Узнаем, какие вершины достижимы из этих. Из правой доли возьмем вершины, которые достижимы, а из левой те, которые не достижимы. Можно понять, что их будет сколько надо.

            • »
              »
              »
              »
              »
              »
              »
              13 лет назад, # ^ |
              Rev. 2   Проголосовать: нравится +5 Проголосовать: не нравится

              Ну а ответ — это просто все вершины, которые не входят в минимальное вершинное покрытие.

»
13 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

кто-нибудь может рассказать нормальное решение Д?

  • »
    »
    13 лет назад, # ^ |
    Rev. 2   Проголосовать: нравится 0 Проголосовать: не нравится

    Думаю, тут наиболее понятно будет, хотя у меня зашло и более простое(но не могу доказать, почему верное):
    делаем ленивую ДП(Х,У,кто ходит): — при входе ставим что еще считаем ее
    — если есть ход в проигрышную позицию, то ответ выигрышная
    — если есть ход в ничью, то ответ ничья, при отсутствии хода в выигрышную
    — ход в позицию которая еще не до конца обработана = ничейная позиция(то место, которое меня смущает)

»
13 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Как решалась задача І?

  • »
    »
    13 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится

    там формула выводится. можно заметить что искомая площадь будет площадью n-угольника минус суммарная площадь лишних маленьких треугольников. если сделать рисунок — будет сразу видно. То есть через данный радиус описанной окружности (R = 10 м)найдем сторону n-угольника, а дальше все несложно находится(так как многоугольник правильный) . ну и формула площади треугольника через 2 стороны и и синус угла между ними

»
13 лет назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

а как решались A и J?

  • »
    »
    13 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится

    В А:
    будем перебирать 2 числа 1е и 2е, потом перебирать с конца середину палиндрома и искать перевернутое начало, откинув середину. Аналогично потом делаем с 2м и 3м числом, так-как нужно зафиксить большую часть палиндрома, эти случаи все покрывают, выходит что-то типа О(N*N*Len*Log(N)) с маленькой константой.

  • »
    »
    13 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится

    В J:
    Тут нужно для кажого И — найти А(и) так что-бы отрезок А(И)..И не содержал в себе равных чисел. А дальше будем бин поиском искать отрезки которые нам подходят и лежать полностью, и те которые частично перекрываются с началом и концом: главное что нужно не забыть, что если i A[i]<=A[j].

  • »
    »
    13 лет назад, # ^ |
    Rev. 2   Проголосовать: нравится 0 Проголосовать: не нравится

    J: посчитаем массив p[i] — максимальный индекс, такой что на отрезке [i..p[i]] нет повторяющихся, понятно, что при увеличении i p[i] не уменьшается.

    посчитать p[i] можно поддерживая левый указатель — i, правый — r и сет отрзезка [i..r], при переходе из i в i+1 удалять из сета a[i]. когда стоим в каком-то i, двигаем r пока можем — пока в отрезке не встречаются повторяющие (проверяем с помощью сета).

    построим теперь дерево отрезков для максимума: в ячейке i храним p[i] — i + 1, т.е длину

    ответ на запрос [Lq;Rq] делаем так: так как p[i] <= p[i + 1] <= p[i + 2]... найдем бинпоиском такое r, что p[r] <= Rq, а p[r + 1] > Rq на отрезке [Lq, r] найдем максимум.

    теперь надо обработать отрезки, которые частично пересекаются, очевидно, что проверять элементы с индексами j (j < Lq), нет смысла, т.к. p[Lq] >= p[j] (опять же), и [Lq..p[Lq]] имеет не меньшее пересечение с отрезком запроса, чем [j..p[j]]. стоит проверить только отрезок [r + 1..p[r + 1]], отрезки [r+2;p[r + 2]], [r+3;p[r+3]]... нет смысла проверять (по той же причине p[r + 1] <= p[r + 2]), отрезок [r + 1..p[r + 1]] будет наибольшее пересечение с запросом