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

Автор riadwaw, 12 лет назад, перевод, По-русски

Остался последний шанс пройти во второй раунд TopCoder Open 2012

Рануд начинается в 20:00 MSK.
Регистрация уже открыта

Не забудьте, что разрешено только 2000 регистраций(Из которых больше 500 занято уже сейчас, через полчаса после открытия регистрации)

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

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

Что это за троллинг? Ведь long long же действительно не нужен в 250, а 500 можно решить, вообще не доказывая?

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

    Я 500 доказал. Я сначала неправильно прочитал задачу и подумал, что от нас требуют восстановления таблички. Если рассматривать ребра в порядке топологической сортировки от старта к финишу и для всех ребер, для которых не выполняется неравенство max(u) + w(u, v) ≠ max(w), где max(u) — длина максимального пути до вершины, а w(u, v) — вес ребра, увеличивать их вес до нужной величины, то получится как раз нужный граф. Почему? Потому что этот граф будет графом "кратчайших наоборот" путей (для него это условие необходимо и достаточно, если я не ошибаюсь), а значит, любой путь будет кратчайшим, то есть равным максимальному. А ребра с каких-то из исходных максимальных путей мы не трогаем, потому что для них это неравенство всегда изначально верно.

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

      Не совсем понял, что именно тут нужно доказывать. Ясно, что до каждого узла все пути должны иметь одинаковый вес, если мы знаем наименьший суммарный вес до узлов (i — 1, j) и (i, j — 1), то сразу знаем и для (i, j).

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

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

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

Киньте, пожалуйста, какой-нибудь гадкий тест на 1000.

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

После этого СРМа я начал ненавидеть кроликов, может кто-нибудь рассказать решение последней задачи?

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

    Подождите до окончания систестов :). Решения-то рассказать можно, но нет гарантии, что они правильные.

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

    Я решил так: подсчитал количество вхождений каждой буквы. Если у нас больше одной непарной буквы, выводим -1, иначе — ставим непарную букву в центр (если она имеется), потом двигаемся слева направо до середины, если у текущей буквы пара стоит не на месте — ставим ее на место. Разумеется, количество обменов считаем.

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

      Такое же решение, жаль не успеть додебажить. Кстати, может быть выводить надо -1, если количество непарных букв больше n mod 2(где n — длина пароля)?

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

        В строке четной длины не может быть нечетного кол-ва букв, которые встречаются нечетное кол-во раз. Поэтому это эквивалентно.

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

          Спасибо, теперь ясно. Все равно на решение не повлияло было.

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

По-моему, первая была самая сложная =)

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

вообще говоря очень странно. 1000 была для меня очень лёгкой. Я её буквально за 5-10 минут придумал и написал, а вот 500 как раз сложноватая...Систесты не прошла

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

Я чего-то не подумал, что квалификация будет проще обычного СРМа, и потратил и в 500, и в 1000 кучу времени на доказательство решения. На мой взгляд, 1000 сложнее — его я там так и не доказал, послал на авось. А сначала вообще написал какое-то более сложное решение с поиском количества циклов в перестановке, которое к тому же оказалось неверным.

Да, это ведь нерейтинговый раунд?

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

    rated

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

    TCO раунды всегда были рейтинговыми

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

    А что там доказывать? Нельзя разложить цикл длины n меньше, чем в n-1 транспозицию.

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

      Меньше-то понятно, что нельзя, но непонятно, почему алгоритм не сделает больше шагов, чем нужно. Ведь, казалось бы, в процессе жадника мы можем сделать какие-то неоптимальные транспозиции.

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

        а, так у меня не жадник. Я дфсом нашел все циклы

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

          Я пытался так сделать, но, наверное, не ту перестановку находил. Я говорил, что если буква встречается первый раз, то она должна здесь остаться, а если второй, то она должна пойти симметрично первому вхождению. Но это ломается тестом aabcbc. По такому алгоритму в середине должны оказаться и буква b, и буква c.

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

            соединяем буквы ребром, если они стоят на симметричных позициях

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

китайцы начитирили