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

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

Всем привет!

Мы рады сообщить, что 6 октября в 15-00 состоится очередной контест, подготовленный командой Samara SAU Teddy Bears.

Этот контест использовался для определения команд, которые будут выступать за Samara SAU в сезоне ACM ICPC 2012-2013. Контест будет несложный, видимо, немного попроще предыдущего нашего контеста.

Контест закончился! Спасибо всем, кто в нем участвовал. Теперь вы можете написать виртуальный контест (регистрация по этой ссылке), или просто дорешать задачи.

Что еще надо сказать:

  • Ввод-вывод: стандартный консольный (такой же, как в раундах Codeforces)

  • Пользователям GNU C++ не рекомендуется читать и выводить 64-битные числа с помощью %lld

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

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

Сделай ссылки относительными:
/team/212,
/gym/100030.

Иначе ты рискуешь перекинуть участника (например, меня) с http://www.codeforces.ru на http://codeforces.ru и напомнить о баге, что авторизация не сквозная

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

    Это не баг

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

      Категорически не согласен. Это баг, но легкообъяснимый. Я считаю, что codeforces.ru и codeforces.com — зеркала, отличающиеся языком по умолчанию и авторизировавшись на одном, я автоматически должен авторизиваться на другом. Не могу представить ситуацию, когда отсутствие такого — ожидаемое поведение.

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

Почему так не любят %lld?

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

Бампище

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

Возможно ли будет начать эту тренировку в 16-00 виртуально? Например, тем, кто опоздает на час.

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

    Нет, придется ждать окончания. Вопросы по этому поводу, как понимаете, не ко мне :)

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

а будут ли свеченые задачи?

на сколько сложный контест, примерно по сложности такой как региональные командные олимпиады в Самаре?

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

Скиньте условия. Ссылка не работает.

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

Хороший контест. Как решать F и H?

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

    В H легко показать, что нам достаточно знать размер самой большой кучки. Будем обозначать позицию через размер этой кучки. Тогда если позиция вида 2^k-1 (т.е. размер максимальной кучки 1, 3, 7...) — она проигрышная. Иначе мы своим ходом всегда можем поделить так, чтобы размер максимальной кучки стал проигрышным — и поэтому позиция выигрышная.

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

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

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

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

      Поэтому хранить в сете можно пары <число, глубина>. На каждой итерации находить наименьшее число, больше нового, и наибольшее, меньше нового, можно с помощью встроенных операций сета.

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

А где-то можно увидеть стендинги с Самарского оффлайн контеста?

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

    Ну так призраки есть. Галку "показывать неофиц" ткните.

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

      Тогда призраки наоборот убираются.

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

        смотря в каком состоянии перед этим был монитор

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

          То есть? Открываю монитор, там все и галочка, убираю галочку, убираются призраки, нажимаю стрялR, страница перезагружается, показываются только участники без призраков, нажимаю галочку, появляются призраки вместе со всеми. Что значит смотря в каком состоянии?

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

            Значит если сейчас их нет, они появляются, иначе убираются. Я предположил, что у него их в момент задания вопроса не было.

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

              Понятно, я подумал что вопрос именно в том, чтобы посмотреть отдельно результаты онсайта. И я думаю, что этого функционала явно не хватает.

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

Как решалась D?

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

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

    Для этого найдем все делители числа N, это можно сделать за sqrt(N). Теперь посчитаем легкую динамику: dp[i] — количество способов добраться до числа i от 1. Для каждого делителя "влоб" будем перебирать все делители же, в которые мы можем из него можем перейти и обновлять для них ответ.

    Так как делителей N порядка N ^ (1 / 3), то наша программа будет иметь время работы примерно O(sqrt(N) + N ^ (2 / 3)) = O(N ^ (2 / 3)), что прекрасно влазит по времени, также как и массив размера N по памяти.

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

Как Е — фальшивомонетчики решить?

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

    (p*p+q*q)/(p+q)

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

      а почему именно такая формула?

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

        Вероятность равна сумме вероятностей двух событий. 1) Перед нами первая монета, и при следующем броске она упадет орлом 2) Перед нами вторая монета, и при следующем броске она упадет орлом

        Первая вероятность равна (p/(p+q))*p. p/(p+q) — вероятность того, что перед нами первая монета; p — вероятность орла во втором броске на этой монете.

        Аналогично вторая равна (q/(p+q))*q. Просуммировав, получаем указанную выше формулу.

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

        Вероятность того, что в первый раз выпадет орёл — 0, 5p + 0, 5q. Вероятность того, что в первый раз выбрана первая монета и выпадет орёл — 0, 5·p. Известно, что в первый раз действительно выпал орёл, поэтому по формуле условной вероятности вероятность того, что выбрана первая монета — . Для второй монеты, соответственно, вероятность быть выбранной есть . Далее, если выбрана первая монета, то вероятность получить орёл при втором броске есть p, если вторая — q. Поэтому общая вероятность есть

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

Thanks a lot to the following participants for their solutions of problem J:

You made my day :D

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

    Treap?

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

      Cartesian Tree!

      Actually, the last one is Splay Tree o_O

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

        Splay is not too hard, if you understand it. I think i did. Even with complexity analyse. Treap is common only in russia and close contries. Mostly they use AVL or RB, as far as i know. They both have same rotate as Splay. And this is the only hard place to code.

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

      Cartesian tree ^_^

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

А как адекватно сделать I? Я делал бинпоск с мапами (правда с мапами упало по тл, пришлось делать с сетами, правда с сетами упало по тл, пришлось делать с приорити_куеуееееее).

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

    Достаточно одной priority queue. Нетрудно понять, что в каждый момент времени выгодно выбирать самый дорогой экзамен. Отсюда решение: итерируемся по моментам времени, в каждый момент времени заносим в priority queue все экзамены, которые становятся доступны сейчас, а потом достаем самый дорогой. Так делаем, пока не обработаны все экзамены, или пока priority queue не пуста. Очень простое решение за N*log(N).

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

      Блиииин. Точно. А я что-то сразу свёл задачу к такой: бинпоиском выбираем максимальную цену за экзамен, считаем для каждого экза время первого и последнего возможных дней, и далее пытаемся сдать все экзамены в соответствии с поставленными рамками.

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

        у меня такое же решение, только я потом избавился от бинпоиска.

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

        я запускал это решение в 2 прохода — сначала считал суммарное количество увеличений макс. цены на 1, а потом вторым проходом уже находил точные положения точек.

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

    Представим, что мы не сдавали экзамены, пока последний по хронологии экзамен не станет доступен. В этом случае у первого экзамена будет стоимость cost[1] + (day[n] — day[1]), у второго — cost[2] + (day[n] — day[2]) и т.д. Очевидно, что тогда оптимально будет сдавать экзамен с максимумом такой величины.

    Но в каждой величине присутствует day[n], если мы его вычтем из каждого значения, порядок не поменяется. Значит мы нашли критерий сравнения двух экзаменов: cost[i] — day[i]. Чем выше этот показатель, тем раньше экзамен надо сдавать.

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

    Все, для решения все готово. Экзамены будем для простоты хранить в куче (heap, priority_queue). На каждом экзамене пытаемся сдать экзамены, уже находящиеся в куче, если возможный день их сдачи раньше дня открытия текущего экзамена. После этого пихаем в кучу текущий экзамен и переходим на следующую итерацию. В конце надо не забыть достать из кучи оставшиеся в ней экзамены.

    Асимптотика решения, как видно, O(n * log(n) + n * log(n)) = O(n * log(n))

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

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

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

    Да

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

    Ну если лень с ними возиться и хочется побыстрее получить Accepted, можно было сделать бинпоиск (так как разница площадей сначала одного знака, а потом другого), или вообще тернарник :D

    А так, конечно, два указателя решают.

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

    Я сделал тернарнк. Получилось весьма быстро.

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

Это невероятно. В задаче J я не подумал про список. Тогда, была, конечно, возможность писать дерамиду, но в голову пришёл один оффлайн изврат. Идея такая: пробегаем данные один раз и выясняем конечную позицию. Дальше запихнём в сет все позиции от 1 до сколько_будет_в_конце, и пойдём по входным данным назад: при insertLeft уберём из сета первую позицию левее текущей, и на неё в массиве запишем данное число; аналогично при insertRight; при moveLeft идём на первую позицию справа, которая есть в сете; moveRight аналогично, слева; если print, то запомним для него позицию. После этого пробежим по массиву, и в пустые ячейки запишем значения изначального массива. В конце концов идём по всем print и печатаем значения массива по запомненной соответствующей позиции. Кошмар.

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

Can someone explain me why the answer is Constantine in the first sample test in problem H?

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

Никого не удивляет, что победители сдали две задачи (E и J) одновременно с плюса на 53 минуте? Вообще разрешается участникам команды писать раунды за несколькими компьютерами?

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

    На тренировках это формально не запрещено... Так что это вопрос, насколько сильно будет мучать совесть по этому поводу.

    Кстати, во время контеста в онлайне был только один аккаунт из этой команды, другое дело, со скольки компов под ним одновременно сидели. Возможно, что они на самом деле играли с одного компьютера, две задачи подряд — такое все-таки бывает, а убирать из таблицы за такое — жалко. Тем более что когда-нибудь в этот контест придет vepifanov и наведет в нем порядок :D

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

I can't understand the sample I/O of problem E. I think the answer is (p + q) / 2,could you please tell me how to get the correct answer?

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

    Probabilities of choosing the coins before and after the first throw are not equal.

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

    It's an application of Bayes' theorem.

    P(B | A) = P(A |^| B) / P(A) = (1/2 * p * p + 1/2 * q * q)/(1/2 * p + 1/2 * q)

    P(B) = probability to get heads on the second throw, P(A) — probability to get heads on the first throw. P(A |^| B) — probability to get heads on both throws.

    So P(B | A) is the probability to get heads on the second throw if we are given that we got heads on the first one.

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

Задачи хорошие.

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

Кстати, учащиеся 11 класса — поступайте в СГАУ! Посмотрите, как у нас легко отобраться на соревнования ACM ICPC! Можно целых пять сезонов участвовать! Это вам не МГУ или СПбГУ или ИТМО, где некоторые команды оранжевых, а то и красных на NEERC никогда не попадали!

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

    а у вас общаги дают?

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

    Я слышал, что у вас отчисляют :D

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

      А я слышал, что пофиг ^_^

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

        Ок, как к вам можно перевестись?

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

          Как минимум, можно закончить бакалавриат в своем вузе, а потом поступить к нам в магистратуру. Перевод — это уже сложнее, подозреваю, что надо поискать на сайте универа, в частности, там есть такая пдфка. Ждем тебя в нашем любимом универе :)

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

    Хорошо, мишки, не буду портить вам рекламу. Сегодня на вашей улице праздник. СГАУ — замечательный вуз. И очень радует, что вы многие свои локальные соревнования выкладываете в тренировки. Другие вузы, следуйте примеру :) Хотя то, что написано в предыдущей правке, не перестает быть правдой.

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

      Согласен почти со всем. Хотя то, что написано в предыдущей правке, не перестает быть правдой :D

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

      Ололо. Битва рекламистов. Я в магазин за попкорном...

      UPD. Ну вот :(

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

Как и предыдущий контест, этот так же прошел на высоте. Спасибо за хорошую организацию и хороший проблемсет. Жаль что мы тупили в концовке.

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

Прорешал вчера контест виртуально. Несмотря на то, что задачи в-принципе легкие, E, F и H мне очень понравились.

Кстати, какое количество задач у вас считалось проходным?

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

Could someone give me the editorial for problems of this contest?

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

Pls explain the approach for Problem J — Product Innovation

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

How to solve M

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

    Go all vector saving the last occurrence of the value v [i] was in position i, and then for each current position look at it already existed an equal element earlier, if so, create an edge of the current position for this last occurrence. Just make a bfs or dp to find the shortest path.

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

How to solve problem H? I thought in grundy numbers, but I dont see independent stacks.

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

Why does this submission for problem A TLE Submission ,, is my HashSet causing this TLE?

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

Why isn't Grundy working for H? How to approach this one?