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

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

Всем привет!

В это воскресенье пройдет московская олимпиада школьников по программированию для 6-9 классов. Над туром работала Московская методическая комиссия, известная вам также по Открытой олимпиаде школьников по программированию, Московской командной олимпиаде и олимпиаде Мегаполисов (раунды 327, 342, 345, 376, 401, 433, 441, 466, 469, 507, 516, 541, 545, 567, 583, 594).

Раунд состоится 23.02.2020 12:05 (Московское время). Вам будет предложено 5 задач и 2 часа на их решение. Раунд будет рейтинговым для второго дивизиона (рейтинг ниже 2100). Как обычно, участники из первого дивизиона могут написать контест вне конкурса.

Задачи соревнования подготовлены KiKoS, DebNatkh, grphil, Sehnsucht, voidmax, isaf27 под моим руководством.

За координацию раунда и перевод условий спасибо cdkrot, а так же MikeMirzayanov за системы Codeforces и Polygon, который использовался при подготовке задач этой олимпиады.

Всем удачи!

UPD1:

Разбалловка: 500 — 1000 — (1000 + 1000) — 2000 — 2500

Заранее сообщаем, что из-за проведения официального соревнования исходные коды других участников будут недоступны ещё час после окончания раунда.

UPD2: Победители!

Div. 2:

  1. SARS-CoV-2
  2. kvk1920
  3. Crazy_Diamond
  4. KwanghyunOn
  5. pufanyi

Div. 1 + Div. 2:

  1. amnesiac_dusk
  2. jiangly
  3. SARS-CoV-2
  4. wiwitrifai
  5. cookiedoth

UPD3: Разбор

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

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

Nice!The start time of this contest was very friendly to the Chinese. :-)

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

I still have questions...

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

    It can be a new contest format or something like global rounds(div.1+div.2)

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

Not colorful testers, but good testers.

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

is this rated contest?

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

I just wanna be specialist again, so I hope it will be easy to solve C at least :)

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

bonne chance

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

3am for people in North/South/Central America, but I'll surely do a virtual participation when I wake up :). Good luck everyone!

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

It's been a long time for Chinese to participate in a proper time.:-D

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

why do some of the rounds listed have div1 while some don't?

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

    as lots of people can make div.2 problems, but div.1 is something else, much harder and much more important. also if you can make div.1, then you will add two simple problems to it, then it would be div.1 + div.2, but you cant add div.1 E/F that much easily. and its the reason that we dont have too many div.1 only rounds, but we have lots of div.2 + div.1 rounds and more div.2 rounds.

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

One year after Codeforces Round #541?? And the same author?

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

Opencup and round at the same time, not cool man, not cool

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

It's sort of crazy to have two rounds one after another, with an interval of only a couple of hours. I'm so excited! LOL

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

    have the same feeling :), what if we participate in this round as a warm up for the next one?

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

      The second round is, however, time-unfriendly to Chinese participants. Rounds like this one are known as "sudden death round" among Chinese OIers since they're in the midnight. I guess my parents won't let me take part in this round. (sad face

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

        i havent ever seen a cf round that has bad start time for us, love Iran :D, this contest was 12AM, and the normal cf round are about 6PM here

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

          Damned. We almost always have to burn the midnight oil to take a cf round.

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

Let's hope this contest has some actually good problems and not some garbage with cows everywhere.

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

    Disagreed. Cows aren't making problems garbage. I think they are making them easier to understand.

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

а кто-то будет писать этот раунд в офлайне.

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

Wish to see questions with good learning aspects.

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

Dyakw

1st edition:

Main specifications: 500 — 1 000 — (1250 + 750) — 2 000 — 2 500

God's law is not protected by the main code.

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

Nice! The start time is great!

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

All the best everybody.

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

Lol, score distribution can be really useful for on-site participiantes, You know

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

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

Please let me add 5 points

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

The start time is so nice to Chinese! Hope to be a Master or a Candidate Master!

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

Yeah <3 I am ready and exiting to join the contest !

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

No Legendary registered!!!

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

Thanks for the Round, but I left when I failed to solve pretests for problem-A , and didnt even understood problem-B in first 30 mins :(

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

Question plz! Why is this contest Div.2 instead of the first five problems of Div.1+Div.2?

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

B is very nice. It should've been C though.

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

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

D̶i̶v̶ ̶2̶ ❌

Div1/1.5 ✔️

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

    haha :D

    I cant solve B for 2 hours ;-; How stupid I am for a math problem

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

      dude i couldnt solve problem B, look at my rating, so that i gave up writing the segment tree on C2 and left the conest :(, the gravity is pulling my rating to newbie

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

        Are you going to drop the rank like I am now ? ;-;

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

        I know B is not always easier than C but I still try all of formula I can think to solve B first and I failed ;-;

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

        New experience for me: Change problem if you think you cant approach furthur although you tried your best for an hour ;-; What a math problem ;-;

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

        I hope we will rank up the next contest :D Good luck <3

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

          thx dude, no hard-feeling, its just a contest which wasnt good for us, maybe next round well get +300 rating(shotor dar khaab binad panbe dane)

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

            Good luck ! Hope I can solve A-B-C and get +50 too

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

              And I solved A-B-C <3, how about you

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

              But I didn't feel too good, since it took me 40 minutes to understand B, and I submited wrong code for C because I was hurry ;-; If I have more time, I hope I can still solve D <3

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

How to solve C2???

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

B is a very nice problem :)

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

    No, it is a horrible index fiddling with absolutly nothing to learn. You might be happy if you solve it, but that does not make it nice.

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

      Not the solution. I meant the idea of the problem is nice. I agree. There is nothing to learn from it.

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

is the solution of C2 segtree+binary search.got tle with that

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

    instead of seg tree do sparse table

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

    For each position i you should calculate the total size of increasing buildings ending at that position.

    Which is equvalent to the Next smaller element problem.

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

    My solution is O(n), you can count all values using stack

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

    Simply segment tree will do

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

      Can you explain the Segment Tree approach for C2?

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

        for each element , we need the closese element on the left of it and on the right of it that has value less than equal to it.So maintain a minimum seg tree and for left and right both elements for each index, do it seperately. For elements in between ,they contribute value equal to element value to its answer. For the rest of elements,answer is already found before. Say for left partition, ansL[i] = ansL[left] + arr[left] + (i-1-left)*arr[i].Same is done for right partition. And then ans[i] = ansL[i] + ansR[i] + arr[i].

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

    No. It is sth like lineral dp + non-decreasing stack. The time complexity is O(n). Plus, I think n=500000 is aimed at preventing some O(nlogn) solution.

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

    I used a different approach.

    I built the cartesian tree of the array in O(n). Basically, each subtree represents a contiguous sub-array. And the root of a subtree is the index of the minimum element of the subarray. It's left and right childs are respectively the sub-array to the left, and to the right of the min.

    Once I have that, I compute the solution for each subtree. Noticing that the buildings size must be constant either on the left subtree, or the right subtree. So I can calculate the answer in O(n) for all subtrees.

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

    You can do binary search on the segtree and use logn time instead of log^2n. You can check my submission https://codeforces.me/contest/1313/submission/71698666

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

    It can be done using a stack. First, we calculate the maximum score we can make from the left side (all buildings in non-decreasing heights) and the right side (all buildings in non -increasing heights). We can do this by maintaining a stack with increasing values. Then taking maximum among all index for left[index-1] + right[index].

    Link

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

how to solve c1 ? i got wrong answer on pretest 3 my code: 71682077

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

    Try putting each element as peak element and the left part forms a increasing segment and the right part a decreasing segment, compute maximum answer for all peaks, and then take the maximum one.

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

How to solve B?

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

    Form min place let $$$lx = min(n-x-1, y - 1), ly = min(n - y - 1, x - 1)$$$. $$$Ans_{mn} = max( y-1-lx, x - 1- ly) + 1$$$. For max place $$$lx = min(n-x, y - 1), ly = min(n - y, x - 1)$$$. $$$Ans_{mx} = max( y-1-lx, x - 1- ly) + lx + ly + 1$$$. Maybe its too complicated, but I came with only this solution

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

How to solve B

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

How do you solve B? It took me over an hour to even come close to a submission. My logic was to casework on N, and the sum of A & B, but I'm pretty sure this isn't correct. This is what I came up with.

if (N == 1) {
    cout << 1 << " " << 1 << endl;
    return;
}    

else if (N == 2) {
    if (min(A, B) == 1 && max(A, B) == 2)   
        cout << 1 << " " << 1 << endl;
    else if (A == 1 && A == B)
        cout << 1 << " " << 1 << endl;
    else
        cout << 2 << " " << 2 << endl;

    return;
}

if (N >= (A + B))
    cout << 1 << " " << (A + B - 1) << endl;
else {
    cout << ((A + B + 1 - N)) << " " << N << endl;
}
»
5 лет назад, # |
  Проголосовать: нравится -8 Проголосовать: не нравится

cool contest but not a good contest problem C idea were really cool but problem B....

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

difficulty balance be like :

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

What is test 8 in C1 be like ?

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

anoyne else solved c1 but couldn't A??

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

i got WA on some testcase in problem A.

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

    This is what I was about to go for, then made triplets using sruct lolol

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

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

Is intended sol for D dp[index][mask] which means we use chosen segments, corresponding to mask, covering point of coordinate index? My code is a mess, I need to transform mask for each transition, there has to be a simpler solution.

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

    How would you transition to a new index?

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

    I pretty much got the same, including the mess and the fail at pretest 2 (and couldn't correct in time)

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

    You can preprocess the intervals in order and map each interval to one of the available bits:

    whichBit.resize(n,-1);
    vector<bool> used(8,false);
    for(int i=0;i<at.size();++i){
    	for(auto interval:out[i])
    		used[whichBit[interval]]=false;
    	for(auto interval:in[i]){
    		int bit=find(used.begin(),used.end(),false)-used.begin();
    		whichBit[interval]=bit;
    		used[bit]=true;
    	}
    }
    

    If you want to set / unset an interval, you should use (1<<whichBit[interval]).

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

Problem B gave me atcoder vibes.

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

Was D something like $$$dp[pos][mask]$$$ denoting max happy children for current position and the mask of the intervals taken?

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

System test will run after 30 minutes? Or right now?

Reason —

"Due to the official competition source codes of other participants will not be available for an hour after the end of the round."

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

Once editorial is published, I'm going to learn much useful stuff

and you know, problem B, I won't let you discourage me!

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

Thanks for this contest. I know my real rating now. I can't solve a Div.2 B for an hour.

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

    Haha :D

    Me too ;-; I thought that B is always easier than C so I tried my best to solve it, and failed ;-;

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

    Actually I spent almost 40 minutes on Problem A after I solved B & C. I did not see the condition that at most one portion is allowed, and was completely stuck.

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

      Oh, and I can only solve the max position of B in first 10 minutes but 1h50 minutes left I cant solve the min position ;-;

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

      Hope you will solve A, B, C in 45 mins in the next contest :D

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

Does anyone have any ideas about div2-D/E?

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

    D, can you explain sample test?

    "In this case all children will be happy except the third." The third kid gets 3 candies, which is odd, so it should be happy. Kids 2 and 4 get two candies, should be unhappy. ???

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

      Only 1-3 and 3-5 are chosen, so 1,2,4,5 will have one candy and thus be happy, while 3 has two candies and is unhappy.

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

I had a hunch that solution of C2 could be related to dilworth theorem?Is it true?

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

Короче, выводы:

  1. B была очень простой, любой кто не решил тот лох)0)))

  2. Авторы потрясающе справились с балансом и сортировкой задач по сложности.

  3. Очень классно, что проводятся такие раунды. Действительно хорошие, годные, приятные задачи, многое из них можно вынести и научиться. Спасибо авторам, вы замечательные люди.

Если что, я вообще без токсичности и иронии. Все чистая правда.

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

Претесты для С — говно(((

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

For the problem B

The worst position is min(n,x+y-1) Reason: we can always arrange (first k natural)(we have this set 2 times) numbers with minumum sum k+1.

eg. k=5 we have set1 = 1,2,3,4,5 and set2= 1,2,3,4,5 so to get the minumum sum we can arrange 1+5, 2+4, 3+3 (=6)

so if x+y is 6 we can have at most 5 players ahead of Nikolay. in general we can have at most x+y-1 players ahead of Nilolay.

The best position is 1 if x+y<=n by the logic mentioned above

else (when x+y>n) we will try to find the number of pairs of a and b such that a+b>x+y

to do this efficiently lets have a target=min(n+n,x+y+1)

to reach the target set a=n so b=target-a

thus b is the best position achievable.

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

    What's wrong with the following code?

    ll n,x,y; cin >> n >> x >> y;
        ll best,worst;
        if (x+y<=n) cout << 1 << " ";
        else
        {
            best=min(n,1+x+y-n);
            cout << best << " ";
        }
        if (x+y<=2) cout << 1;
        else
        {
            worst=min(n,1+x+y-2);
            cout << worst;
        }
    
    • »
      »
      »
      5 лет назад, # ^ |
        Проголосовать: нравится 0 Проголосовать: не нравится

      It is copied, not linked.

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

      I am not able to understand why have you written worst = min(n,1+x+y-2);

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

        It just ended up like that while i was coming up with the idea, it's equivalent to x+y-1 anyway so it doesn't really matter, what does matter is why it's giving WA on test 3.

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

          You have done the same thing... what I did.

          Don't know why WA on test3.

          Just a matter of some kind of bad luck :(

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

            Thanks for giving it a thought, i'm really puzzled with this :/

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

              you forgot cout<<endl; lol consider having 5 tests you need to do cout<<endl;

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

Coronavirus wins!!!!

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

how to solve C2 anyone?

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

    linear dp + non-decreasing stack

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

    The final array of the answer can of these 3 forms :

    1). Non-decreasing order
    2). Non-increasing order
    3). Non-decreasing order upto some index i, then non-increasing order from i+1 to n.
    

    Part 1 and 2 is straight forward. For 3rd part we will do some preprocessing. Let's construct two arrays Pre, Post.


    Pre[i] will contain the number of floors we can make if the array is in non-decreasing order starting from 1 to i. Post[i] will contain the number of floors we can make if the array is in non-increasing order starting from i to n.

    let's calculate array Pre.

    Consider 1 based indexing.
    Pre[i] for a particular index will be (i - j) * arr[i] + Pre[j]. Here j is **largest** index of element which is smaller than arr[i] to the left of it. If no such j exists then j = 0. More formally, arr[j] < arr[i] and j < i. Index j can be calculated using stack.
    

    Similarly Post array can be calculated. And the array will be splitted at the point where pre[i] + post[i+1] is maximum. See this for stack method.

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

      that's what i was going to write, but i was about to use segment tree instead of the idea to move over indexes. thx for the solution

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

        I too used Sparse table + binary search for such type of problems until i read the editorial of this problem from Codeforces.

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

      Thank u so much. Nice explanation.

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

Will we get to see testcases used?

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

I couldn't find a O(1) math solution for first integer in B,so i just used binary search to find it :) (nice C btw)

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

    haha, nice bro <3

    ;-; Sad for me trying all the O(1) formula I can think with no result

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

Div.2 $$$\times$$$
Div 1.414 $$$\surd$$$
Difficulty:A<C1<B<C2<<D<E

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

Can any one tell the approach of A I just list out cases for it. Any other method?

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

    I used greedy method

        /// Sort a > b > c
        if (a < b) swap(a, b);
        if (a < c) swap(a, c);
        if (b < c) swap(b, c);
     
        int res = 0;
    
        /// Take 1 disk
        if (c) res++, c--;
        if (b) res++, b--;
        if (a) res++, a--;
        /// Take 2 disks
        if (a && b) res++, a--, b--;
        if (a && c) res++, a--, c--;
        if (b && c) res++, b--, c--;
        /// Take 3 disks
        if (a && b && c) res++, a--, b--, c--;
    
        cout << res << endl;
    
  • »
    »
    5 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится

    Notice that you should take (a-b) and (a-c) before take (b-c) else you will get WA

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

When will be the rating change?

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

My code for C1 gave an incorrect answer on the 9th pretest. Any idea what's wrong with it? 71676960

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

Why fake123_loves_me just disappeared in the standing? He was first, but he disappeared and everyone else's standing get one step upper.

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

B is very hard

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

Can anyone provide the solution for C1? Thanks in advance!

  • »
    »
    5 лет назад, # ^ |
      Проголосовать: нравится 0 Проголосовать: не нравится
    int n;
    cin>>n;
    
    int a[n];
    for(int &i:a)cin>>i;
    
    int ans[n];
    
                int sum3=0;
                int index=0;
    
                for(int ind=0;ind<n;ind++)
                {
                    int tsum=0;
                    int temp[n];
                    tsum+=a[ind];
                    temp[ind]=a[ind];
    
                    for(int i=ind-1;i>=0;i--)
                    {
                        temp[i]=min(temp[i+1],a[i]);
                        tsum+=min(temp[i+1],a[i]);
                    }
                    for(int i=ind+1;i<n;i++)
                    {
                        temp[i]=min(temp[i-1],a[i]);
                        tsum+=min(temp[i-1],a[i]);
                    }
    
                    if(tsum>sum3)
                    {
                        index=ind;
                        sum3=tsum;
                    }
                    //cout<<tsum<<endl;
    
    
                }
              //  cout<<index<<endl;
    
                  ans[index]=a[index];
                    for(int i=index-1;i>=0;i--)
                {
                    ans[i]=min(ans[i+1],a[i]);
    
                }
                for(int i=index+1;i<n;i++)
                {
                    ans[i]=min(ans[i-1],a[i]);
    
                }
                for(int i:ans)cout<<i<<" ";
    • »
      »
      »
      5 лет назад, # ^ |
        Проголосовать: нравится 0 Проголосовать: не нравится

      Sharing code is not appreciated here. Better share links if you really have to; even better share your approach!

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

I think B may change position with C1

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

    How can you solve B ? That is nice <3

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

      Suppose in the first round we took x-th place and in the second round — y-th place

      First we consider the max: We can let the person who took (x-1)-th place in the first round took the (y+1)-th place in the second round. Then the total score of this participant is (x+y) which can contribute to the answer .Similarly, with this strategy we can know that the ans is min(n,x-1+y-1+1)

      Then we consider the min: We can let the person who took (x-1)-th place in the first round took the (y+1+1)-th place in the second round. At this moment , the total score of this participant is (x+y+1) which is strictly larger than we. By doing this,now1=max(0,n-(y+1)) of the first (x-1) people's final scores are strictly larger than B.The same is true for the dimension y and the number is now2. So the number of people who may not strictly larger than we is (a-1-now1+b-1-now2+1(myself)), but this is not the optimal answer, We can make pair X and Y smaller than me in pairs and make the ans to {a-1-now1+b-1-now2-min(a-1-now1,b-1-now2)+1}

      My Submission : 71671193

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

      worst pos is min(n, x + y — 1) best pos is (x + y >= n ? min(n, x + y — n + 1) : 1)

      proof is left as an exercise to the reader

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

engrossing contest : )

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

Can problem E be solved using suffix array?

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

Участников во время соревнования: 350

Тестирование задачи занимает 3 минуты КАК?

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

Without samples, I couldn't solve B

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

Finally Master. Hope I can stay a bit longer.

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

I cant see the code of others (it is almost 2hrs)

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

I THINK I VE COME UP WITH THE ULTIMATE GENIUS 35182798 IQ THINKING PROCESS FOR SOLVING B.

First you reduce the problem to a matching problem 71692875. I copypasted preflow pushes but it doesnt really matter!!! You could use ford-fulkerson or any other algorithm.

Then you notice a pattern and write this 71692875. Then you submit it and do not lose 5512571829 rating.

I think I am a fucking genius right guys?

Proof by AC is the way to go smart people told me this!!

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

    actually i wonder how many of those who got an ac actually know why their solution works

    i dont

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

      You didnt even submit your super solution. In both of ur submission you got AC using the same 1 line of code.

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

My code for C2 (here got the wrong answer. But when I changed at line 118 from '<' to "<=", it got accepted. I tried that to handle the case of all zeros (even though it is outside the constraints). Is their test case 20 outside of constraints or am I missing something?

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

Does anyone have the similar situation?

The System says I may write a code very similar to other's.

But this is problem A.

I think it's because the code is too simple so that it's easy to be very similar.

What should I do?

My Submission:71656145

What the system has sent to me:

Attention!

Your solution 71656145 for the problem 1313A significantly coincides with solutions Acranker/71656145, hnust_zhouzisheng/71662017. Such a coincidence is a clear rules violation. Note that unintentional leakage is also a violation. For example, do not use ideone.com with the default settings (public access to your code). If you have conclusive evidence that a coincidence has occurred due to the use of a common source published before the competition, write a comment to post about the round with all the details. More information can be found at http://codeforces.me/blog/entry/8790. Such violation of the rules may be the reason for blocking your account or other penalties. In case of repeated violations, your account may be blocked.

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

Why do i keep getting runtime error on test 5 in D? Here's the link to my code

EDIT: Got the mistake

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

When will the system tests be visible, I want to know why my C2 failed!!!!

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

tfw you're purple but can't solve div2 B...

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

When will submission be visible? It's nearly 3hrs instead of so-called "1hr"! And I'm anxious to see why my C2 failed!

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

Я видел всего 3 задачи (2, не считая разделение на простой и сложный вариант) из варианта для 7-8 классов. Остальные взяты из варианта для 9? (Я писал тур за 7-8 классы и не видел вариант за 9, если у кого есть условия за 9 класс, подскажите, где их можно найти. Спасибо.)