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

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

Здравствуйте!

Рад пригласить Вас принять участие в моем первом кратком соревновании на codechef.com, в воскресение, 20:00 по Москве. Раньше я уже давал несколько задач для длинных контестов, но это первый полный контест, все задачи которого подготовлены мной. Стоит также отметить, что контест мне помогал и помогает готовить Anton_Lunyov, за что ему отдельное спасибо.

Для участие в соревновании Вам достаточно зарегистрироваться на сайте, дополнительной регистрации на соревновании не нужно. Контест пройдет за стандартными правилами ACM-ICPC, Вам нужно будет решить 5 задач за 2,5 часов. Первые 10 участников получают призы от организаторов.

Сразу после соревнования будет опубликован разбор. Также после соревнования здесь можно будет обсуждать задачи а также написать мне все что Вы думали об задачах и что хотите увидеть в будущем.

Удачи!

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

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

Lucky numbers again? I like them! :P

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

Как решалась LUCKFILL? Мой перебор почему-то получает WA.

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

    Возможно что-то лишнее отсекаешь. Мой перебор упорно ловит ТЛ, хоть локально и летает.

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

    Предподсчет.
    Для всех Н <= 50, K = 50 запомним ответы, а потом на каждый тест просто возьмем и проверим все что нашли: для Н=11 их максимально кол-во(2048).

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

      k = 50 — опечатка? А запоминаем ответы — это значит перебираем все возможные строки с отсечением?

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

        Нет, не опечатка. Перебор не заходит из за того что его много раз вызывают на Н=11, и он кучу раз выполняет много лишних операций. А так мы запомнили ответ для худшего теста и просто проверяем: помещается или нет строка под шаблон и кол-во различных подстрок.

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

      А их точно 2024? Просто даже если рассуждать логически, выходит 2048. Всего у строки длины 11 есть 11 * 12 / 2 = 66 подстрок. Подстрок длины 1 всего бывает 2: "4" и "7", а мы же посчитали что их 11, значит надо из 66 вычесть 9. Подстрок длины 2 всего бывает 4, а мы посчитали что их 10, значит надо вычесть еще 6. Подстрок длины 3 всего бывает 8, а мы посчитали что их 9, значит надо вычесть еще 1. Получаем 66 - 9 - 6 - 1 = 50. Значит, нам подходит любая строка длины 11, т.е. ответ 2048.

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

        Извини, на автомате написал. Там 2048.

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

у кого-нибудь еще не работала кнопка submit в последние 4 минуты контеста?

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

Кто расскажет как решать "Little Elephant and CNSes"? А то для N>=1000 знаю решение, а вот для маленьких не совсем.

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

    (Наверно, у меня не самое простое решение)

    Рассмотрим для какой-то строки функцию f(c4,c7) — минимальное количество замен, чтобы в строке оказалась подпоследовательность из c4 четверок и c7 семерок. Эта функция возрастает по каждому параметру (и кое-где равна бесконечности). Будем использовать два "указателя": возрастающий c4 и убывающий c7. каждый раз, увеличив c4 на 1, будем уменьшать c7, пока замен слишком много в сумме по всем строкам.

    Осталось научиться поддерживать f(c4,c7), умея увеличивать c4 и уменьшать c7 на единичку за амортизированное O(log чего-нибудь).

    Для каждого символа (точнее, каждого промежутка между соседними символами) в строке посмотрим, какой будет функция f(c4,c7), если поместить "центр" (переход от 4 к 7) подпоследовательности сюда. Тогда f(c4,c7)=const+c4+c7, если c4 и c7 достаточно малы, иначе — бесконечность (на самом деле там больше случаев). Значит для получения f(c4,c7) достаточно уметь находить минимальное const из всех подходящих по диапазону c4 и c7. Можно поддерживать множества позиций, подходящих под текущие c4 и c7 и обновлять его при изменении c4 и c7. Много деталей опущено, там достаточно запутанная реализация получилась.

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

      Блин, дошел до этой функции. Но писал бинарный поиск. И не понимал как соптимизить.

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

Спасибо за интересные задачи!

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

You can read the editorials here.

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

Клевые задачи, спасибо!

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

что-то какой-то сложный разбор Little Elephant and Balance, напишу свой, может кому-то поможет.

поймем, когда строку можно разбить на две сбалансированые. начнем движение сначала строки, будем поддерживать количество четверок — х на префиксе, и семерок — y на суффиксе, перед началом строки x = 0, y = кол-во семерок в строке, когда мы сдвинемся на позицию вперед произойдет одна из двух вещей, количество четверок станет равно х + 1, либо количество семерок станет равно y — 1...

очевидно, что таким образом когда-нибудь х станет равен y, потому что у нужно уменьшится на y — x, y уменьшится на количество семерок в худшем случае, очевидно, что количество семерок не меньше, чем y-x, становится понятным, что этого не произойдет тогда, когда все строка равна 7кам, потому что Х <= |S|, а берем мы первые Х — 1 элемент. т.е. в ответ не войдут подстроки вида 777...77, то есть из общего количества строк n * (n + 1) / 2 нужно отнять все такие подстроки. профит

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

    Примерно тоже самое написано в абзаце разбора "Proof of the author". Просто в начале дано совершенно другое решение с деревом Фенвика и потом я привёл ещё своё доказательство.

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

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

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

    Одна из причин, как я думаю — Codeforces в принципе не позволяет никому увидеть решения владельцев контеста ни до, ни после.

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

      Некоторые авторы дают ссылки на свои решения в разборе, так что я не думаю, что КФ не позволяет этого делать. Или я не так уловил мысль, и подразумевалось то, что это технически невозможно?

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

задачи хороши, даже не смотря на то, что они все однотипные (нет графов, геомы или еще чего-нибдь)

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

    Ты считаешь, что графы и геометрия это верх разнообразности задач?
    Думаю от геометрии и реализации всех тошнит. А идейные задачи нравятся большинству.

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

      я что-то против сказал?

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

      Тем не менее, мне как-то надоело весь контест думать примерно об одном и том же.

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

      Ну не знаю, я совсем не рад задаче LUCKFILL. На кодшефе компьютеры какие-то ужасно медленные и очень тяжело сравнивать время на сервере с локальным временем. Я дописал кучу отсечений к перебору, он очень быстро работал локально, но на сервере всего раз получил ВА, когда я неправильное отсечение добавил. А так он то и делал что ТЛил. Я не сделал прекальк, т.к. не видел, почему оно должно было что-то кардинально изменить, т.к. в переборе и так куча оптимизиций была. А оказалось, что именно это решало.

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

где дорешивание?

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

А на codechef есть возможность смотреть ранклист контеста?

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

While upsolving this contest, I found one Codechef feature: when you submit a problem and go to campus.codechef.com, in recent activity you see submission status. Difference with codechef.com is that if your solution is running you will also see some number in parentheses under running icon. Apparently, this is the number of test your solution is curently tested on(sometimes you can also see "running judge" with number too).

I also found out that your solution is actually tested against the whole testset even if it fails on some intermediate test. However, execution time will be only counted on first tests you passed plus the first test you failed (I mean time that will be shown to you if you get Wrong Answer). It's only my guess of course, but I strongly believe this is how their judge works.