Автор BledDest, история, 7 лет назад, По-русски

Привет, Codeforces!

15 июня в 18:05 MSK состоится Educational Codeforces Round 23.

Продолжается серия образовательных раундов в рамках инициативы Harbour.Space University! Подробности о сотрудничестве Harbour.Space University и Codeforces можно прочитать в посте.

Раунд будет нерейтинговый. Соревнование будет проводиться по немного расширенным правилам ACM ICPC. После окончания раунда будет период времени длительностью в один день, в течение которого вы можете попробовать взломать абсолютно любое решение (в том числе свое). Причем исходный код будет предоставлен не только для чтения, но и для копирования.

Вам будет предложено 6 задач на 2 часа. Мы надеемся, что вам они покажутся интересными.

Задачи вместе со мной готовили Михаил awoo Пикляев и Владимир vovuh Петров. Благодарим за помощь в тестировании Алексея Perforator Рипинена, Алексея ashmelev Шмелёва и Максима HellKitsune Финютина.

Удачи в раунде! Успешных решений!

UPD. Рад анонсировать вторые сборы Hello Barcelona Programming Bootcamp (в сотрудничестве с Moscow Workshops ACM ICPC), которые будут проводиться нашими партнёрами Harbour.Space University совместно с Moscow Workshops ACM ICPC, Университетом ИТМО, МФТИ, СПбГУ и Codeforces!

Подробная информация о сборах.

UPD: Разбор задач.

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

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

WOW !! Editorial has been published before the contest.

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

    Sorry, we fixed it now.

    Anyway, it was a link to the ER22 editorial, so it would not help anyone with this round.

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

Please correct the time of the contest

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

Автокомментарий: текст был обновлен пользователем BledDest (предыдущая версия, новая версия, сравнить).

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

Today is Champions Trophy Semifinal INDIA vs BANGLADESH ....Timing issue

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

servers are getting really slow. Hope the contest won't be delayed

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

    The contest will surely delay, it is tradition.

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

      Hey, it's a tradition for usual rounds but not for ERs! Previous 5 rounds started at the time they were scheduled.

      Though I really don't like current condition of servers too.

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

Judgement failed??

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

What is Judgement Failed?

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

What is Judgement Failed?

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

Me too! Don't worry. Round will be unrated. xD

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

Are pretests too weak? I am submitting crap and they all are getting "accepted" as of now.

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

Large amount of hacks on A and B is coming...

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

I think problem F could be solved using segment tree if the interval was smaller... Can it be solved using a lazy-constructed segment tree? (we create nodes as we need them)

Thanks! :)

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

    the answer is always l[i] or r[i] + 1 for some i , so just coordinate compress these points and then use normal segtree.

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

    I think we can compress the value of L and R and then build a segment tree with the new value (1 — 200000) and then use lazy-constructed segment tree as you said.

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

    Sparse Segment Tree gives MLE on test 15 :( But shouldn't that pass the ML? It creates ~ 64 nodes per update. Each node has one long long and one short.

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

      I think when we pushdown lazy tag it will expand more nodes so not just 64 nodes per update ,I guess

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

How to solve F and C?

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

    C was a binary search :)

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

    the sum of the digits can't be large, so there's not many numbers x such that the check x - digitsum(x) >  = s is interesting. Check them all and add the rest in O(1), I checked only the interval [s..min(s+200,n)].

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

    It can be proved that if a > b then a — sum_of_digits(a) >= b — sum_of_digits(b) so we can do binary search to find the smallest n that n — sum_of_digits(n) >= s

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

    All numbers from s+9*18+1 to n are really big. So you can check numbers from s to s+9*18 and add max(0, n — s+9*18)

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

    C is really a brute force problem.

    It was supposed to be A.

    Just iterate through s+1 to max(n, s+160) and find where
    this condition met -> (s+i) — sum_of_digit(s+i) >= s.
    then just print (n — (s + i) + 1).
    if not met then just print 0.

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

Any idea for D? I thought something on basis of RMQ and adding one element at a time to the array. But it is TLE easily.

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

How solve D? :'v

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

can we get AC with a NlogN solution in problem D ?

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

Why i cant double click on submissions to hack it???

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

Can't wait until tomorrow to see the verdict. Please try to hack my C. I haven't used binary search or dp. code

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

How to solve D with O(N) complexity?

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

    here you go.

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

    For each element, let the number of subarrays in which it is the min be cnt_min[i] and the number of subarrays in which it is the max be cnt_max[i]. Answer is sum of arr[i]*(cnt_max[i]-cnt_min[i]).

    To find cnt_max[i], for each index i, find the closest indices to its left and right such that value there is > arr[i]. This can be done in cumulative O(n) time using stack. Similar for cnt_min[i].
    Take care of duplicate values.

    Code

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

    The basic idea is for each i find Nmx[i] — the number of subarrays that will have a[i] number as maximum. Then do final_answer += Nmx[i] * a[i]. Similarly find Nmn[i] — number of subarrays in which a[i] will be the minimum number, and do final_answer -= Nmn[i] * a[i].

    Nmx can be found in O(N) time. To find Nmx[i], you have to find Rmx[i] and Lmx[i] such that a[i] is maximum among all numbers in the segment [Lmx[i], Rmx[i]]. Rmx and Lmx arrays can be obtained with a forward sweep and a reverse sweep of the original array.

    Similarly find Nmn array.

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

How to solve E? I could feel the use of tries but I couldn't come up with a good idea.

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

    Read this tutorial to learn how to solve similar problems involving XOR using trie.

    In this problem, maintain a trie in which numbers are inserted/removed in the decreasing order of bits in their binary representation. Now, for the query part, just traverse along the path specified by P and consider all cases in which you can get XOR < L.
    eg. if next bit of P is 0 and next bit of L is 1, you can add all the numbers along the 0-edge to the answer and then move along the 1-edge (because for all numbers inserted in subtree of 0-edge, their XOR with P will be < L).

    You can see all the cases in my code. Code

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

Constraints in the problem E are so good that an O(Q^2) solution gets AC (it's not that the tests are weak: I can't make it run for more than ~1.5 seconds).

Was it intended?

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

    Hacked.

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

      What test did you use? I thought about adding 50000 numbers than query 50000 times.

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

        That's exactly what I did.

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

          That's weird. I didn't try this hack because it worked less than <1.5 seconds using custom invocation (and even a little bit less locally with actual input reading/printing the answer).

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

      Cool. What's the idea of your test case? I tried to do something like adding different numbers K times and than making N — K queries (choosing K to maximize the run time), but it didn't work.

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

      What about this one?

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

Автокомментарий: текст был обновлен пользователем BledDest (предыдущая версия, новая версия, сравнить).

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

The editorial is published.

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

This was another great educational round from your part, I liked the problems a lot, keep up the good work.

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

Why my MEX queries does not work? Here's my code:

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

It seems like that several past educational rounds are full of data structure problems XD

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

    They are :c We really try to balance out problemsets but everytime it ends up with lots of ds problems.

    I guess that it is actually fine in context of ERs because education in competitive programming is mostly about learning algos and data structures. Still somehow I am not pleased with the quality of contests...

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

For B. Makes And The Product I don't know why my logic won't work

27820072

Basically I am counting the frequencies of smallest 3 distinct elements. For example 1 1 1 2 2 3 3 3 3

So the frequency is 1 -> 3, 2-> 2, 3->4 Call them k1,k2,k3 for smallest numbers a1,a2,a3

If k1>=3, it means the constituents of my minimum product all come from a1...So it is k1 choose 3

else if k1==2, then i just choose one of a2, which gives k2 ways.

else if k1==1 and k2>=2, then number of ways is k2 choose 2

else if k1==1 and k2==1, then i have to choose one a3, k3 choose 1 way of doing that.

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

214 successful hacks!! Great!

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

    As usual :D

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

      There is just too few tests for such tricky problems. Authors often use Educational Rounds as an excuse to be a bit lazy.

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

        Which problem was the tricky one?

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

        Well, most of the hacks are made on easier problems. We can't add too many tests for them as it can lead to big server load. I won't deny that we don't try that hard to make tests as strong as possible but it isn't easy to cover all the cases with 10-15 tests.

        There is just about couple of dozens successful hacks for D-F. I suppose that is fine, isn't it?

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

          Server load is definitely a concern. Do you know how bad it is in practice? May be we can afford more tests from B onward?

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

            I'm not sure. As far as I can guess from usual rounds, ~30 tests for task with ~20 submits per minute is about the limit (considering submissions for all problems, not only this one).

            Though it's hard to determine submissions rate before the contest. Adding more tests is always risky.

            I suppose that we can try pushing this limit a bit by rearranging tests. I don't think that A can have more tests than it currently does but for B it's possible, I think. We will try to increase this number in next round.

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

              Use multitests

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

                Great point! Why didn't we even consider it previously? Thanks, next round will definitely include multitest in problems B or C then.

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

                  Because everyone hates multitest? You don't feel progress while fixing bugs and yet still getting WA2.

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

                  It's not a problem to make a couple of somewhat hard testcases of 1 test and place it right after samples...

                  Does everyone really hate it that much?

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

Can anyone explain me D&C solution for D? Because solution with stacks looks awful. I was thinking D&C on contest but couldnt solve it.

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

Can anyone explain me D&C solution for D? Because solution with stacks looks awful. I was thinking D&C on contest but couldnt solve it. Edit: got it. This solution helped me: http://codeforces.net/contest/817/submission/27832753

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

Would you please update the Python2 version for the judging system?

This submission is said to be runtime error for python 2.7.3 while it works perfectly on my macbook with python 2.7.11.

http://codeforces.net/contest/817/submission/27881187