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

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

Привет Codeforces!

Скоро состоится очередной раунд Codeforces Round #302, задачи для которого придумал я, Виталий Гриднев.

Хочу сказать большое спасибо Максиму Ахмедову (Zlobober), Александру Игнатьеву (aiMR), Данилу Сагунову (danilka.pro) за помощь в подготовке задач, Марии Беловой (Delinur) за переводы на английский, Михаилу Мирзаянову (MikeMirzayanov) за замечательные системы Codeforces и Polygon.

Распределение баллов:

  1. Div1: 500 — 1000 — 1750 — 1750 — 2500
  2. Div2: 500 — 1000 — 1500 — 2000 — 2750

Контест закончен, поздравляем победителей:

Div1:

  1. Petr
  2. qwerty787788
  3. -XraY-
  4. kraskevich
  5. Merkurev

Div2:

  1. nka55
  2. never_retired_phoenix
  3. lowsfish

Разбор задач

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

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

"you are lucky to participate in Codeforces Round #302" I think I am lucky to participate all Round :D

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

That's strange! Contests are starting later and later in my country (first 8:00 pm, then 8:30 and now 9:00!), but the time in Codeforces' contests page is the same! Do the time modes in countries change so frequently?!

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

Where are these coders ?! Just 2555 registrants for now ?!

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

    I re-checked my email right now, I didn't received notification about this round. I am visiting CF quite often, so I knew about contest anyway; but some people may actually miss round becuase of missing notification.

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

One more time. A good round on codeforces good luck and have fun everyone!!!!! who do you think will win this round? someone in special ??

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

I hope a nice contest with interesting problems for all the participants.

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

hope problem A isn't going to be HACKY! :D

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

Hoping good results and high ratings... and a lot of hacks!!!

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

I only say I must give up

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

Are all samples included in the pretests or just the first one?

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

Problem B confusing statement cause me a wrong submission. Should codeforces neglect the wrong submission before the announcement ?

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

    oh if we maximize also it gets accepted.

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

    yeah, it is extremely rare that a problem description (in this case div2 B) is changed multiple times during the contest.

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

    Let me clarify what happened during the contest.

    The original statement looked like the following:

    [start of the fragment]

    We will assume that a set of cells is an island, if the following conditions hold:

    • each cell of the set is covered with sand;
    • from each cell of the set you can get to any other cell of the set by moving only through the cells of the set, considering that in one move you are only allowed to move from one cell to a side-adjacent one;
    • you cannot add any cell to the set so that conditions 1 and 2 hold (in other words, the set of cells should be maximal).

    [end of the fragment]

    It is definition of the island that has nothing common with the rest of the statement. The given definition is one of the classical definitions of the connected component: the connected component is a maximal (i. e. unextendable, not maximum size!) set of vertices such that any two of them are connected with a path.

    In English words "maximal" and "maximum" have different meanings. For example, here you can see two different objects: maximum matching and maximal mathcing. When we say maximum, we mean maximum-cardinality. When we say maximal we mean such set that can't be extended with any other element without losing some property. And this was explicitly said in previous statement. It doesn't say that you should have no way to convert sea cell to a sand cell such that conditions 1 and 2 hold; it says that you should have no way to add an existing cell without losing conditions 1 and 2.

    Also, this part describes the definition of island. The actual task follows after this paragraph and it doesn't say anything about maximizing any kind of value. It is also illustrated by the sample test.

    Nevertheless, we've seen many clarification requests asking why the answer to the sample test isn't maximal in some manner. So we decided to clarify this part as possible. We said twice in global announcements that this definition is a usual definition of the connected component. That still didn't work, some people still were asking questions. Then we decided to even rewrite the definition making it less formal (!) but more clear to a newbie. But we want to point out the fact that at no moment the question was incorrect.

    You can try to formulate by yourself what is "connected component", it's not easy to do that without mentioning maximalness in some way. On CodeForces we usually try to provide formal definitions of things used in problems. Unfortunately, it sometimes leads to such issues.

    After a long discussion we decided to leave everything as it is and make the round rated. After all, there were lots of people who understood the statement correctly.

    Also, as someone noticed above in comments, even if you try to maximize something (total size of all components, for example) and you do that correctly, you will get your "Accepted" since our checker accepts all solution that have k connected components, no matter which size they have.

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

      The description that you posted was absolutely correct and unambiguous, you should not have clarified or changed anything. The current description is wrong:

      //start description

      We will call a set of sand cells to be island if it is possible to get from each of them to each of them by moving only through sand cells and by moving from a cell only to a side-adjacent cell. The cells are called to be side-adjacent if they share a vertical or horizontal side. It is easy to see that islands do not share cells (otherwise they together form a bigger island).

      //end description

      Nothing in that description says that a proper subset of an island isn't be an island. Not only is it not "easy to see" that islands don't share cells, it's wrong: if they share cells, they form a bigger island, but they're still islands anyway.

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

        That's what I mean by less formal. Of course you are right but the saddest part is that tens of questions per minute almost immediately disappeared when we rewritten the statement in such informal manner.

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

      I don't understand. Is this an island?

      SSS
      SLS
      SSS
      

      It does not satisfy rule 3, you can still add some cells to the set. (Please correct me if I am wrong)

      I understand that you just wanted to say "a smaller subset of cells of an island is not an island". But the definition is problematic here, because, unlike the usual graphs with nodes and edges, you have "sea cells" and "land cells" here.

      The first clarification doesn't help too (it even reinforced the feeling that you have to add as many cell as possible.) The island is the maximal set of sand cells on existing picture (meaning that you can add no new cell from the existing picture without

      Also an alternative way to clarify things is to add an extra sample that contradicts the belief.

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

        You cannot add anything because adding an 'S' will not extend the set because it is not covered with sand.

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

        PlayTheGame is telling everything correctly above. Regarding the alternative way to clarify things: in this case I don't see how adding another sample could have saved the situation since the main confusion already happened because of the first sample test.

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

          Thanks, I agree. I got confused too.

          I think next time better avoid the terms set and connected component in Div 2 A, B as there are many contestants from middle school who never learned about sets, and some contestants are not familiar with graphs (in a problem which does not require knowledge in graphs).

          They are grey, green and blue after all.

          Thanks for the hard work and explaining to me.

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

Решал А 1:40, в последний 10 минут пытался написать B, не хватило 10 секунд, чтобы заслать =( Правда это решение даже тесты из условия не проходит...

UPD: Решение зашло, но его необходимо было отладить и потестить, то есть не хватило минут 10.

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

    а какая идея была в Б не подскажешь ?

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

      Ну за 10 минут до конца я придумал вот что: найдём минимальное расстояние от каждой вершины до каждой другой. После переберём вершину в которой маршруты из двух заданных городов сойдутся, переберём вершину, в которой этот маршрут разойдётся, ну и легко можно всё посчитать. Отдельно рассмотреть случай, когда маршруты не будут иметь общих рёбер. И еще уже сейчас понял, что стоит после этого поменять местами одну пару городов, так как маршруты могут по разному сходится.

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

        найдём минимальное расстояние от каждой вершины до каждой другой

        Как это сделать за 2 сек при n = 3000 ? Флойд не зайдет, Дейкстра для почти полного графа вроде тоже..

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

          n, m <= 3000. n запусков бфс

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

            Спасибо, понял..
            Сегодня не мой день :)

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

          n bfs-ов (все ребра имеют вес 1)

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

          там есть не сразу заметное ограничение на количество рёбер в размере 3000

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

          Эм, либо я туплю, либо простой БФС работает за количество вершин. То есть запустить БФС от каждой вершины. Еще хорошо, что m не более 3000.

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

        Тоже ближе к концу придумал это решение, но упало на систестах. А можно поподробнее про

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

        ?

        UPD: глянул код, понял (проверить ещё swap(s1, t1), точняк).

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

          Думаю на подобном тесте и были сделаны все взломы.

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

What is the hack test of problem D in div1?? I think my solution is correct :(

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

    You can let your code run this case:

    200000

    1 2 2 2 ... 2 2 2

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

      My output for your test is : 543973825 87947641 543973825 543973825 543973825 ...
      Is this correct?

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

    A hack against division via multiplicative inverse: (ideone)

    How to construct it:

    factor 1000000006: 2 500000003
    factor 500000002: 2 41 41 148721
    factor 148720: 2 2 2 2 5 11 13 13
    

    So, to get a subtree with answer 148720, we have to unite eight chains of lengths (2-1) (4 times), (5-1), (11-1) and (13-1) (2 times). After that, the subtree contributes a multiplier of 148721 to its parent. Proceed with constructing 500000002 from three short chains and the 148720 subtree... and so on.

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

      I constructed such test using binary representation of MOD: divide it by 2 while possible and add subtree with one node. when it becomes odd, subtract 1 and build new subtree with it

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

      There is an easier way of getting it, as you can easily add +1, by adding one more edge. 1000000006=6+10^9=6+(1+3*3)^9

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

I am one of those, who was registered, but didn't participate, because.. there were no any strong ideas in any problem..
Imho, there should be at least one easy enough problem in Div.1 in order to have a more honest rating.

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

    Problem Div.1A is a typical dp problem, isn't it?

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

      I don't think so: the naive solution, which I could generate, was O(n^4) and after optimization worked 5 secs at max test. I could not invent any O(n^3) approach during the whole round :)

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

        So, you still think that you didn't participate because the problems were boing or because you get scared by the first problem, which, as far as I can see, you weren't able to do? N ^ 3 was the typical dp, and I heard that there is a solution in N ^ 2 too.

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

          Because I could only solve A in N^4 and have not enough time to finish D.

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

            D could be solve writing a very short code.You said in the above coment that the problems didn't have any strong ideas.I think that they were preety cool E seems awesome even tought I didn't solve it.I couldn't solve C and B was very interesting(In my opinion).You insulted the contest just because you couldn't solve A...

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

              No, you get me wrong: the problems were interesting, but I could not find any solution of them, which i sure enough to code or submit.

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

      Its a variant of knapsack with repetitions allowed.

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

you are lucky to participate in Codeforces Round #302 he said

Good luck and have fun he said

:(

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

Did better than usual, fun problems! Maybe I'll become Green again!

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

How to solve Div2 C Writing Code?

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

    it must be dynamic programming.. my code keep getting WA on pretest 6 anyway :(

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

    f[j][k] — count of plans with j lines and k bugs. f[j][k] = (f[j][k] + f[j-1][k-a[i]]) % mod

  • »
    »
    9 лет назад, # ^ |
      Проголосовать: нравится +1 Проголосовать: не нравится
     MEM(dp,0);
        dp[0][0]=1;
        FOR(i,n){
            FOR(j,m){
                for(int k=0;k<=b-a[i];k++) 
                    dp[j+1][k+a[i]]= (dp[j+1][k+a[i]]+dp[j][k])%v; //dp[i][j] where i represents the number of lines and j represents the number of bugs.
            }
        }
        ll ans = 0;
        for(int i=0;i<=b;i++)
        ans = (ans + dp[m][i])%v;
    

    I got WA 6 because I was running the k loop upto b (instead of b-a[i]) which was causing WA.

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

Problem B was quite confusing. Also the announcement just changed the problem. I think this round should not be rated

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

I guess almost all solutions will fail on testcase when divisibility by 109 + 7 was involved. I thought that my code handled it correctly, but unfortunately not and I was hacked probably using such testcase.

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

    I was hacked also by such a testcase. How can we deal the problem when the number is divisible by 1000000007?

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

      One way of doing it is keeping then number in form a·(109 + 7)b. When it is necessary to divide by 109 + 7 reduce b, otherwise multiply a by modular inverse.

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

        You can't do this in this manner.

        Of course we can't keep a explicitly, because it will grow too large. We also can't keep just the reminder a%109 + 7, because if you have some number x in this representation then you don't know representation of x + 1.

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

          We can actually do it in this particular case. When we pass this value to a child of a vertex, all what we need to know is whether it is zero or not(modulo 10^9 + 7). If it is not zero(that is, b = 0), a mod 10^9 + 7 is obviously a correct value. If it zero(that is, b > 0), it is, again, correct, because it is 0 regardless of a. Put it another way, we never need to add one to a number in this representation.

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

          How to do it, if is not possible to represent x + 1 using the x value of that representation?

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

Anybody else who got WA #11 on Div2 C?

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

Ух, сложные задачки были в пердиве :) Вроде прикольно такие решать, но вот уходить с баранкой после контеста (впервые в жизни) совсем не прикольно :DDD

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

I wrote (almost) correct algorithm for B and D, expecting it to pass. Then I tried to solve C for like 20mins and still have no idea how to solve it. So I decided to code whatever greedy & dp comes to mind (I first code some DP, which got WA5, so I added some greedy).

Now I failed B & D, but my C is correct.

So surprised...

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

    What sort of greedy? I just used set cover.

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

      Uhm, it's very complicated to describe in words, but I'll try.

      So first, about the DP solution:

      • Let's call f(i, S) = minimum cost after we used first i characters, to make the set of strings S good.
      • For each (i, S), I tried each character c. Let S2 be the set of strings where the (i+1)-th character is c --> I use f(i,S) to update f(i+1, S | S2)
      • Note that I always use whole set S2, which is obviously wrong.

      So I updated my DP, allowing adding single character at a time, using min(cost to change this character, cost to change all same characters),

      which I think must still be wrong, and I think the correct thing to do here must be considering all subsets of S2.

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

        If I'm reading your code right, when your DP updates mask | TWO(x) using a single character, mask | TWO(x) hasn't been processed yet, so it can add another single character when you get to that mask.

        So your code actually is considering all subsets, and it is actually the correct solution (iterating over all subsets would clearly TLE).

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

          But how can adding single element at a time like this be correct? In case I add 2 strings x and y with the same character c (at position i), the cost that I'm adding equal:

          min(a(x,i), sum(a(z,i) where s(z,i)==s(x,i))
          + min(a(y,i), sum(a(z,i) where s(z,i)==s(y,i))
          

          In case sum(a(z,i)) is smaller, I added a(y,i) twice.

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

            In case sum(a(z,i)) is smaller, that means update(f[i][mask | maskSet[i][c]], t + costSet[i][c]); is strictly better than your single character update, so that doesn't matter.

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

i cant be happy anymin

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

    Ты уверен, что i <= s.length(); верно?

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

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

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

        Обычная ошибка для экс-паскалистов :) непривычно переучиваться к индексации с нуля, но что поделать? :)

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

You should not maximize the sizes of islands.

That was after a lot of WAs. -_-

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

    I think case 1 itself was self-explanatory that it is not necessary to maximize the sizes of islands. If we had to maximize the size of islands, one of the possible answer could have been: YES

    LLLLL

    LLLLL

    SSSSS

    LLLLL

    LLLLL

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

O(NMB) is too slow for A Div1? I got TLE.

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

The time limit for A is way too tight.

I suppose there was a 500 500 500 case in the pretest. Branch predictor and memory causes it to TLE in system tests.

When I resubmit the same code, case 7's time increased from 25xx ms to 29xx ms.

UPD: gridnevvvit has replied that using long long instead of int causes solution to TLE. I strongly believe that the jury should NOT test for such differences.

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

    Yeah, I have similar issue as I see.

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

    What is the reason to make array size as a power of 2? It leads to problems with cache.

    For example, you can increase 512 to 520 and got Accepted: 11026552 and 11034250.

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

      Thanks for the idea. Next time I won't make it power of 2.

      I never thought that I could get TLE due to branch predictor behavior / cache collision.

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

      Why exactly does this happen?

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

        Because cache internally uses a hash function based on several least significant bits of memory block address. When the second dimension is a power of two, accessing a[i+1][j] will most likely result in a hash collision that will slow down everything.

        More info here: http://danluu.com/3c-conflict/

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

How is Div2 D / Div1 B supposed to be solved?

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

Rule 3 : Ignore rule 3 XD

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

Правильно ли я сделал, что моя первая посылка на контесте была за 17 минут до конца? Или нужно было всё таки подождать окончания и уже тогда засылать, чтобы не рисковать рейтингом. Кто-нибудь еще так делал?)

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

Does anyone know when the ratings will be updated?

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

Worst feeling of missing Rank-1 just because you kept the array size in Problem A one less than what is required. Silly mistakes!! :\ :(

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

I wonder if BFS was an overkill for DIV 2 Probelm B? Also tricky testcase. Watch out for number of island =0! eg-> 1 0. I messed up due to this. COrrected it now to get AC :/

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

    BFS was certainly an overkill for this problem. You just have to create islands skipping one cell after each island. A simple traversal of O(n*n) does the job.

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

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

Например на тесте

4 7

с учётом первоначальных условий решение будет "NO", т.к. есть возможность добавить ещё 1 остров несвязный с остальными, а с новыми условиями ответ будет "YES"

YES
LSLS
SLSL
LSLS
SLSS

Нельзя так на ходу кардинально менять условия задачи :(

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

    Как это NO если: LLSL SSLS SLSL LSLS

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

      Прошу прощения... уже догадался до такого решения :)

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

        Можешь напомнить, как в сообщениях делать переход на новую строку? А то если просто enter один раз — он его убирает, а если два раза — получается дополнительная пустая строка. Я помню, что можно, но не помню как (думаю многие вообще не в курсе, что можно). Хотя я только что нашел способ — тэг br, но вроде был еще более простой.

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

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

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

Problem — A

Why my Solution skipped? — 11027863

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

What is the complexity of this solution 11033699 for Div.1D ?

»
9 лет назад, # |
Rev. 4   Проголосовать: нравится -13 Проголосовать: не нравится

 Is it written anywhere that today's contests are unrated? seems something is missing in the highlighted area which exists in other rated contests!

UPD: Actually I wanted to tell about rating changes, but some reason the picture had not shown. However, Ratings are updated and all confusion went out of the air!

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

good contest but not for beginner :D

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

I wish I had fixed my hacked B 30 seconds earlier......

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

What was the official solution of E. My O(S(32 + N / 32)) passed with 3.7 seconds and 54MB.

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

Расскажите про E.

Я вижу следующий прекалк: сканлайн по значению, а внутри персистентное дерево отрезков с операциями += на отрезке и минимум на отрезке.

Запросы обрабатываем online. Суммарное время (N+S)logN, памяти NlogN.

Весит эта конструкция на макстесте после серии оптимизаций 70 mb. ML = 64 mb.

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

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

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

    Похоже авторы решили завалить это решение, поскольку оно слишком простое. У тебя 70MB чистое решение дало или хорошо нахаченное? У меня решение без хаков занимает около 300MB при n=200000, m=33000 (не очень понятно при каком m достигается наибольшее количество вершин, так что точно сказать не могу). Конечно на запросы максимума я вершины не создаю.

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

      У тебя 70MB чистое решение дало или хорошо нахаченное?

      Да, слегка нахаченное =)

      1. Вершина дерева { int left : 24, right : 24, add : 18, min : 18; } через двоеточие указано число бит, всего получаем 84 бита на вершину 10.25 байт. Всё это пишем битовыми массивами.

      2. Вершина дерева -- это индекс в массиве вершин, т.е. целое число от 0 до 224. На самом деле вершин всего будет 200 000 * 17 * 2 < 7 000 000. Т.е. один бит лишний, сейчас мы этим воспользуемся.

      3. Если всё поддерево равно числу X, то указатель на такое поддерево можно хранить, как число 223 + X.

      4. Изначально дерево пустое, храним его, как root = 223 + 0.

      5. Нужно ещё пояснить, почему за один change (плюс равно на отрезке) будет добавляться не более 17 * 2 вершин, это следует из того, что везде, где можем, мы используем (3).

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

        Персистентное дерево отрезков все таки можно запихать — фишка в том, что нам не надо хранить add, совсем! Мы можем пересчитывать его на лету вот так: add = this.min - min(left.min, right.min).

        Так же одну вершинку можно запихнуть в 64 b, если не добивать все до степеней двойки, а кодировать вот так: encoded = MAX_min * (MAX_left * right + left) + min, где MAX_min = 200 001 и MAX_left = 8 000 000 (у меня вышло чуть менее 8M вершин в худшем случае).

        Вместо твоей оптимизации (3) — не хранил листья как отдельные вершины, просто на предпоследнем уровне вместо left и right хранил соответственно left.min и right.min.

        PS Если кому вдруг интересно — вот сабмит 11072405

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

          Хорош!

          Мне казалось, оптимизация (3) действует не только на уровне листьев. Когда мы делаем один change, нам может понадобиться создать 4logn новых вершин, но на каждом уровне две из четырёх будут вида "отрезок равных элементов".

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

          Круто!

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

Can someone explain why my Solution on Div2 B got a TimeLimit in the first Testcase? On my Computer i got an solution instantly and uploaded it twice in the contest

http://codeforces.com/contest/544/submission/11031166

I noticed that i have an WA as well, but there wasn't enough time to fix both...

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

/**/

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

Could anyone explain how to solve Div1 D? Thanks)

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

What an awful contest?!

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

Спасибо за раунд, задачи было интересно решать на протяжение всего раунда! Жаль только, что сложными оказались :)

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

I didn't receive email notification for this round :(

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

My code (for Div1 D) is getting WA. I couldn't find it. What do you think is my mistake?

Submission: 11058128

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

    0 has no mod inverse.

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

      So, it's not possible to do it by dividing, I can't fix it, right?

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

        I think so. In my solution, I do extra preprocessing during build to get the result by only multiplication. Edit: You can use mod inverse to solve this problem too, but you should treat the cases containing "dividing 0" specially. This can be done by recording more data in your "build" function.

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

Может кто нибудь объяснить задачу Е с див 2_) Заранее спасибо

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

Why the memory limit is 64MB, not 256MB, in Div.1 E?