Vladosiya's blog

By Vladosiya, history, 13 months ago, translation, In English

1907A - Rook

Idea: pashka

Tutorial
Solution

1907B - YetnotherrokenKeoard

Idea: pashka, MikeMirzayanov

Tutorial
Solution

1907C - Removal of Unattractive Pairs

Idea: Vladosiya

Tutorial
Solution

1907D - Jumping Through Segments

Idea: MikeMirzayanov, Vladosiya

Tutorial
Solution

1907E - Good Triples

Idea: pashka

Tutorial
Solution

1907F - Shift and Reverse

Idea: pashka

Tutorial
Solution

1907G - Lights

Idea: pashka

Tutorial
Solution
  • Vote: I like it
  • +27
  • Vote: I do not like it

| Write comment?
»
13 months ago, # |
Rev. 2   Vote: I like it +27 Vote: I do not like it

It would be better if you added formatting for the solution to Problem F.

UPD: Thanks

»
13 months ago, # |
Rev. 4   Vote: I like it +22 Vote: I do not like it

In E, we can also notice that the answer to each digit x(0-9) is simply ((x+1)*(x+2))/2.

Explanation 1: Let, x be split as x=a+b+c. If a=x, b+c=0; this will generate one combination->(x,0,0). If a=x-1, b+c=1; this will generate two combinations->(x-1,0,1) and (x-1,1,0).Similarly you can notice that the total combinations for digit x= 1+2+3+..+x+x+1= ((x+1)*(x+2))/2. So, no need to use the loops to calculate this.

Explanation 2(Suggested by my brother): The combinatorics formula to distribute x as a sum of k non-negative numbers is C(n+k-1,k-1) which here transforms to C(x+3-1,3-1)=C(x+2,2)=((x+1)*(x+2))/2.

Or, you could have just figured this out by looking at the test cases.

  • »
    »
    13 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    How did you get this equation? ((x+1)*(x+2))/2

    • »
      »
      »
      13 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Summation of numbers from 1 to n = (n*(n+1))/2

      • »
        »
        »
        »
        13 months ago, # ^ |
        Rev. 2   Vote: I like it 0 Vote: I do not like it

        Why do I calculate numbers from 1 to x+1 ?

        • »
          »
          »
          »
          »
          13 months ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          I think you might be confused in this line : "Similarly you can notice that the total combinations for digit x= 1+2+3+..+x+x+1= ((x+1)*(x+2))/2. So, no need to use the loops to calculate this." that's why you need to calculate the sum from 1 to x+1. Please correct me if I am wrong.

          • »
            »
            »
            »
            »
            »
            13 months ago, # ^ |
              Vote: I like it 0 Vote: I do not like it

            It is not clear to me why we will stop at x+1 "

            • »
              »
              »
              »
              »
              »
              »
              13 months ago, # ^ |
              Rev. 2   Vote: I like it +1 Vote: I do not like it

              Maybe this will help:

              When a=x, there is 1 combination: (x,0,0)

              When a=x-1, 2 combinations: (x-1,1,0),(x-1,0,1)

              When a=x-2, 3 combinations: (x-2,2,0),(x-2,1,1),(x-2,0,2)

              .

              .

              .

              When a=1, x combinations: (1,x-1,0),(1,x-2,1),(1,x-3,2)----(1,1,x-2),(1,0,x-1)

              When a=0, x+1 combinations: (0,x,0),(0,x-1,1),(0,x-2,2)----(0,1,x-1),(0,0,x)

              Total combinations =1+2+....+x+(x+1)

  • »
    »
    13 months ago, # ^ |
    Rev. 2   Vote: I like it 0 Vote: I do not like it

    This is called stars and bars. U can read more about in this article in TOPCODER https://www.topcoder.com/thrive/articles/Basics%20of%20Combinatorics

  • »
    »
    6 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Was solving this, did the exact thing and then saw the editorial. Why is this solution not in the main editorial?

    • »
      »
      »
      6 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      I guess the problem setters always have their own solution in mind at the time they are designing the problem. This ensures the problem can actually be solved. This is a good approach but it may sometimes happen that the first thought solution is not the the most optimal one. Then during a later reading the setter or a contestant finds a more optimal one. Well, that's the crux of research, understanding the optimizing over known results. Just like how my brother gave an even better understanding over my original solution.

»
13 months ago, # |
  Vote: I like it +5 Vote: I do not like it

Video Editorial For Problems A,B,C,D,E,F,G._

  • »
    »
    12 months ago, # ^ |
      Vote: I like it +3 Vote: I do not like it

    After this video, can you speak English or have subtitles in English for your video so that all coders around the world can understand it?

  • »
    »
    12 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Greeting sir/bhiya

    I am trying this question from tomorrow smjh nahi aarha kaha galti kr raha hu , if you could point it would be great help .

    Link of submission .

    Thankyou

    • »
      »
      »
      12 months ago, # ^ |
        Vote: I like it +1 Vote: I do not like it

      The way you are moving from one node to another while applying topological sort is wrong and also you are code is bit messy while solving around cycle of the graph. You can look at my code to understand it better. My code

»
13 months ago, # |
  Vote: I like it 0 Vote: I do not like it

wasn't able to participate in this contest, but the problems were very good, I think. although G does feel like it reduces down to just applying a standard graph algorithm, no?

  • »
    »
    12 months ago, # ^ |
      Vote: I like it +1 Vote: I do not like it

    Yes, topological sort with some greedy approach.

»
13 months ago, # |
  Vote: I like it +12 Vote: I do not like it

Video solution for Chinese:

BiliBili

»
13 months ago, # |
Rev. 2   Vote: I like it +29 Vote: I do not like it
My DP solution for E - Good Triples
»
13 months ago, # |
  Vote: I like it 0 Vote: I do not like it

Can someone explain F,i don't understand tutorial at all.

  • »
    »
    13 months ago, # ^ |
    Rev. 2   Vote: I like it +20 Vote: I do not like it

    You can think that:

    1. RR <=> 0(doing nothing)
    2. SRS <=> R

    So, we can conclude that:

    1. There will be no consecutive R
    2. It doesn't make sense to insert R in consecutive S

    The final structure must have a long string of S's in the middle, and an optional R at the beginning and end.

    • »
      »
      »
      13 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Thank you very much!

    • »
      »
      »
      13 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      how does writing the array twice and then looking at the increasing and decreasing segments help ?

      • »
        »
        »
        »
        13 months ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Such array contains all shifts of initial one, if there is an increasing or decreasing segment of length $$$n$$$ it is one of the shifts we are searching for.

    • »
      »
      »
      13 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      How can someone reach SRS===R condition?(How to think of this condition,intuition wise)

      • »
        »
        »
        »
        13 months ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Consider RSR, you move the first element of array to the last place, and shift all other elements to the left, it's a reversed operation to S, so S(RSR) will not change the array, therefore SRS === R:)

»
13 months ago, # |
  Vote: I like it +2 Vote: I do not like it

In C, how do you prove that if no character appears more than floor(n/2) times, we can always achieve n%2 length of the final string? Please help.

»
13 months ago, # |
  Vote: I like it +1 Vote: I do not like it

Nearly 24 hours have passed, and the rating still doesn't change?

»
13 months ago, # |
  Vote: I like it 0 Vote: I do not like it

Is the reason why editorial's check function for Binary Search works trivial? Because after x steps, if the intersection with the segment is non empty => I have one sequence of steps that lands me after x steps inside that interval. It does not ensure that those steps are consistent with the last x-1 regions right? (It should since the editorial is right, but I don't see how we can prove it.)

  • »
    »
    13 months ago, # ^ |
      Vote: I like it +3 Vote: I do not like it

    Consider the segment after x steps, if you can find one with intersection. For all points inside this segment there is a point in the last segment you could have reached it from. In other words you can pick any point in the current valid segment, and there is a point in the last segment from where you could reach this. You can continue this reasoning to the first segment. I agree, this is not that trivial to see.

»
13 months ago, # |
  Vote: I like it +13 Vote: I do not like it

Thank you for such a wonderful round pashka, Vladosiya, MikeMirzayanov. I will be looking forward to a new and interesting round from you.

»
13 months ago, # |
Rev. 2   Vote: I like it 0 Vote: I do not like it

Hi, can anyone tell me why this is TLE in Python but AC in C++?

Python: 236125120 it is TLE without the fastIO line as well.

C++: 236125273

I am having an identity crisis.

*accidentally posted the comment in Russian, my apologies for the spam

  • »
    »
    13 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Because string concatenation via + is very expensive operation in Python. Here is you code but string and s += are replaced with array and s.append(). It passes. 236138895

»
12 months ago, # |
  Vote: I like it +14 Vote: I do not like it

Is this Tutorial written for those who don't need it?

No proof, No explanation, Only conclusion. Oh, yes, I completely understood

»
12 months ago, # |
  Vote: I like it 0 Vote: I do not like it

236178810 Can Anyone tell me what is wrong in the mentioned code.

»
12 months ago, # |
Rev. 2   Vote: I like it +16 Vote: I do not like it

The problems are great, but I feel that the editorial is written rather poorly.

Here is a (hopefully) more intuitive editorial of problem F -

Let us consider the inverse of the operations given in the original problem, for the sake of better understanding.
Given a sorted array in non-decreasing order $$$s$$$, you can perform two operations:
- Shift Inverse: move the first element of the array to the last place, and shift all other elements to the left, so you get the array $$$s_2,s_3,...,s_n,s_1$$$.
- Reverse: reverse the whole array, so you get the array $$$s_n,s_{n-1},...,s_1$$$.

By observation, we realize, that there are three types of arrays that arise when we perform the above operations on some sorted array $$$s$$$:
i) The most basic of it is the reverse of $$$s$$$ — the array $$$s_n,s_{n-1},...,s_1$$$.
ii) An array of the form $$$s_k,s_{k+1},...,s_n,s_1,s_2,...,s_{k-1}$$$, $$$1<k \le n$$$.
iii) An array of the form $$$s_k,s_{k-1},...,s_1,s_n,s_{n-1},...,s_{k+1}$$$, $$$1 \le k<n$$$.

Thus, we can break down the original problem into the following cases:

  1. If $$$a$$$ is sorted — No moves required, answer is $$$0$$$.

  2. If $$$a$$$ is sorted in reverse order — reversing the array solves it, answer is $$$1$$$.

  3. If $$$a$$$ is of the form presented in case ii) above —
    Let us break the array into two parts: the first part being the part of $$$a$$$ corresponding to $$$s_k,s_{k+1},...,s_n$$$ (let us call this part $$$F$$$) and the second part being the part of $$$a$$$ corresponding to $$$s_1,s_2,...,s_{k-1}$$$ (let us call this part $$$S$$$). We can solve this in two ways —
    (a) perform the 'Shift' operation on all elements of $$$S$$$. So total number of moves = $$$|S|$$$.
    (b) perform the 'Reverse' operation on $$$a$$$, perform 'Shift' operation on all elements of $$$F$$$, and then perform the 'Reverse' operation again. So total number of moves = $$$|F|+2$$$.
    We take the minimum of (a) and (b), and that is our answer.

  4. If $$$a$$$ is of the form presented in case iii) above —
    Let us break the array into two parts: the first part being the part of $$$a$$$ corresponding to $$$s_k,s_{k-1},...,s_1$$$ (let us call this part $$$F$$$) and the second part being the part of $$$a$$$ corresponding to $$$s_n,s_{n-1},...,s_{k+1}$$$ (let us call this part $$$S$$$). We can solve this in two ways —
    (a) perform the 'Shift' operation on all elements of $$$S$$$, and then perform the 'Reverse' operation. So total number of moves = $$$|S|+1$$$.
    (b) perform the 'Reverse' operation on $$$a$$$ and then perform 'Shift' operation on all elements of $$$F$$$. So total number of moves = $$$|F|+1$$$.
    We take the minimum of (a) and (b), and that is our answer.

  5. If $$$a$$$ is neither of the cases presented above, then the answer is $$$-1$$$.

C++ code for reference.

»
12 months ago, # |
  Vote: I like it 0 Vote: I do not like it

[DOUBT][PROBLEM G] — > can someone explain how to find minimum number of operations to turn off all turned on lights in the cycle? firstly, we will remove/turn off all nodes with in-degree=0 and will keep on removing till we find the cycle. I am struck after this point.

  • »
    »
    12 months ago, # ^ |
      Vote: I like it +2 Vote: I do not like it

    Find any light that is on in the cycle. There are only two ways for it too be turned off — either you directly flip it's switch or you flip the switch of the previous node in the cycle. Once you've chosen the starting node to start flipping you can move through the greedily flipping any lights that are on. Calculate the number of flips for both starting nodes and choose the smaller.

»
12 months ago, # |
  Vote: I like it +2 Vote: I do not like it

The editorials are very hard to understand, specially for E, F and G. :)

»
12 months ago, # |
Rev. 2   Vote: I like it 0 Vote: I do not like it

:D

»
12 months ago, # |
  Vote: I like it 0 Vote: I do not like it

In Problem E. 1907E — Good Triples Can someone please tell the proof for:

"A triplet is considered good only if each digit of the number n was obtained without carrying over during addition."

This is a good observation, but how can I prove such information or approach it at least?

»
12 months ago, # |
Rev. 2   Vote: I like it 0 Vote: I do not like it

There exists a hashing solution to problem F.

You can save two hash values , one for the sorted non-decreasing array and the other for the sorted non-increasing array.

Then, you can try doing the operations on the original array or on the reverse of it ( with additional cost of one operation). Doing the operation on an element which is the last in array is simply subtracting the element from the current hash, dividing by base and adding this value * base ^ (n-1).

Then, the first moment where the hashes are equal , we have found an answer to minimize over it and stop doing operations.

Link to submission: https://mirror.codeforces.com/contest/1907/submission/236598692.

P.S I found this solution more understandable than what is written in the tutorial.

  • »
    »
    11 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    But hashing ( although the probability is very small) may lead you to collisions in the worst case..

    • »
      »
      »
      11 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Probability of collision with double hashing is very very small : )

»
12 months ago, # |
  Vote: I like it 0 Vote: I do not like it

For problem C, why is it true that we can remove all possible pairs regardless of the order of deletions if no character occurs in the string more than n/2 times? For example, in the string aabbcc it does matter the order of deletion, because if we just deleted ab and ab we would be left with cc which is not optimal.

»
12 months ago, # |
  Vote: I like it 0 Vote: I do not like it

can someone explain problem D

»
11 months ago, # |
  Vote: I like it 0 Vote: I do not like it

wo bu neng li jie ni xie zhe ge ti jie shi gei wo zhe zhong cai ji kan de dong de ma?!

»
11 months ago, # |
  Vote: I like it 0 Vote: I do not like it

There’s my view of the solution of problem E (in understandable English). https://youtu.be/VKqPUNGcD0k

»
9 months ago, # |
  Vote: I like it 0 Vote: I do not like it

I have got a very easy solution for problem E i.e for which digit of input number, you have certain combinations available. so, its better to mulitply those combinations for each of the digits of input number. Also, you can pre-compute the combinations for each digit(0-9) by simply observing the test case.

»
7 months ago, # |
  Vote: I like it 0 Vote: I do not like it

For Problem D, how do we develop the segment where we end up ourselves after $$$ith$$$ iteration?
How do we prove that $$$[ll,rr]$$$ are always the bounds we find ourselves?

»
5 months ago, # |
Rev. 2   Vote: I like it 0 Vote: I do not like it

If anyone want solution for question F , i have explained in comments in simple words 273078914

»
4 months ago, # |
  Vote: I like it 0 Vote: I do not like it

My approach for Problem E:

Suppose there are n identical balls (0 <= n <= 9) arranged horizontally. Also, there are two identical bars that we will be using to separate the balls into three groups.

xOxOx...xOx

Here 'O' represents a ball and 'x' represents a position where you can put one of the bars. Thus there are n+1 such positions to put the first bar.

Let us put the first bar arbitrarily as follows:

xOxOx...xOxBxOx...xOx

Here 'B' represents a bar.

Now there are n+2 positions where you can put the second bar.

But the two bars are interchangeable, so we will have to divide by 2.

Thus for n, there are (n+1)*(n+2)/2 ways of arranging them. (Remember, here 0 <= n <= 9.)

We have to do the same for all the digits and multiply them.

Here is my solution (in PyPy3-64):

https://mirror.codeforces.com/contest/1907/submission/278685323