Edvard's blog

By Edvard, history, 9 years ago, translation, In English

600A - Extract Numbers

This is a technical problem. You should do exactly what is written in problem statement.

600B - Queries about less or equal elements

Let's sort all numbers in a. Now let's iterate over elements of b and for element bj find the index of lowest number that is greater than bj. We can do that using binary search. That index will be the answer for value bj.

Complexity: O(nlogn).

600C - Make Palindrome

Let's denote cntc — the number of occurences of symbol c. Let's consider odd values cntc. Palindrome can not contain more than one symbol c with odd cntc. Let's denote symbols with odd cntc as a1, a2...ak (in alphabetical order). Let's replace any one of symbols ak with symbol a1, ak - 1 with a2 and so on until the middle of a. Now we have no more than one odd symbol. If we have some let's place it in the middle of the answer. First half of answer will contain occurences of symbol c in alphabetical order. The second half will contain the same symbols in reverse order. For example for string s = aabcd at first we will replace d by

Unable to parse markup [type=CF_TEX]

in the middle and after permuting the symbols we got abcba. Easy to see that it's the optimal solution.

Compexity: O(n).

600D - Area of Two Circles' Intersection

If the circles don't intersect than the answer is 0. We can check that case with only integer calculations (simply by comparing the square of distance between centers with square of the sum of radiuses). If one of the circles is fully in other then the answer is the square of the smaller one. We can check this case also with only integer calculations (simply by comparing the square of distance between centers with square of the difference of radiuses).

So now let's consider the general case. The answer will be equal to the sum of two circular segments. Let's consider the triangle with apexes in centers if circles and in some intersecting point of the circles. In that triangle we know all three sides so we can compute the angle of the circular segment. So we can compute the square of circular sector. And the only thing that we should do now is to subtract the square of triangle with apexes in the center of circle and in the intersecting points of circles. We can do that by computing the half of absolute value of cross product. So we have the following formulas:

,

where d is the distance between centers of the circles. And also we should do the same thing with second circle by replacing of indices 1 ≤ ftrightarrow2.

Complexity: O(1).

600E - Lomsat gelral

The name of this problem is anagram for ''Small to large''. There is a reason for that :-) The author solution for this problem uses the classic technique for computing sets in tree. The simple solution is the following: let's find for each vertex v the ''map<int, int>'' — the number of occurences for each colour, ''set<pair<int, int>>'' — pairs the number of occurences and the colour, and the number sum — the sum of most frequent colours in subtree of v. To find that firstly we should find the same thing for all childs of v and then merge them to one. These solution is correct but too slow (it works in O(n2logn) time). Let's improve that solution: every time when we want to merge two map-s a and b let's merge the smaller one to larger simply by iterating over all elements of the smaller one (this is the ``Small to large''). Let's consider some vertex v: every time when vertex v will be moved from one map to another the size of the new map will be at least two times larger. So each vertex can be moved not over than logn times. Each moving can be done in O(logn) time. If we accumulate that values by all vertices then we get the complexity O(nlog2n).

I saw the solutions that differs from author's but this technique can be used in a lot of other problems.

600F - Edge coloring of bipartite graph

Let's denote d is the maximum degree of vertex in graph. Let's prove that the answer is d. We will build the constructive algorithm for that (it will be the solution to problem). Let's colour the edges one by one in some order. Let (x, y) be the current edge. If there exist colour c that is free in vertex x and in vertex y then we can simply colour (x, y) with c. If there is no such colour then there are a couple of colours c1, c2 so that c1 is in x and not in y and c2 is in y but not in x. Let's make vertex y free from colour c2. Denote z the other end of edge from y with colour c2. If z is free from colour c1 then we can colour x, y with c2 and recolour y, z with c1. So me make alternation. If z is not free from colour c1 let's denote w the other end of the edge from z with colour c1. If w is free from colour c2 then again we can do alternation. And so on. We will find an alternating chain because the graph is bipartite. To find the chain we can use depth first search. Each chain contains no more than O(n) vertices. So we have:

Сложность решения: O(nm).

  • Vote: I like it
  • +58
  • Vote: I do not like it

| Write comment?
»
9 years ago, # |
  Vote: I like it 0 Vote: I do not like it

Hi,

Do you have an English translated version of your blog?

Thanks.

»
9 years ago, # |
  Vote: I like it +18 Vote: I do not like it

How do you ensure that your formulas are precise enough? It is pretty easy to come up with those formulas, however it is much harder to convince yourself (and guys preparing tests) that it will be sufficiently precise on tests like:

999999999 0 1000000000
-1000000000 0 1000000000
  • »
    »
    9 years ago, # ^ |
      Vote: I like it +21 Vote: I do not like it

    As one particular example, the formula found here (equation 13) is not precise enough, at least without BigDecimals, while the editorial's formula works with long double (and some double mixed in).

    The only difference between my two submissions 14517685 — WA28 and 14533916 — AC is that the second uses the formula from the editorial, while the first is from the above link.

    The two formulas are almost the same, but differ in one part that is subtracted. I think the reason is that the imprecise formula involves taking the square root of a product of four terms, which might compound the error or something. Could someone shed some light on this?

    • »
      »
      »
      9 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      The way to ensure this is to avoid at all costs substration or addition of floating point numbers. If we are adding floating point numbers we'd better ensure they are of the same sign. In other words, stick with ints as long as you can. I saw two problems (not sure if they equally serious):

      1) the acos(x) function is flat for x near to 1. So in these cases it would be preferable to determine the angle though asin. It is possible to calculate a precise length of the perpendicular from the circle crossing onto the line connecting the centers. I did it using Heron's formula for area of a triangle. Therefore we can use asin instead of acos.

      2) calculating asin(x)-x for small x. I did it using Taylor series around x=0.

      Solution: http://pastebin.com/LV5qaK1Q

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

    i calculate sin alpha using the area of the triangle s = 1/2 * (r1 * dis)* sin(alpha) then i calculate s using s = sqrt(p * (p — r1) * (p — r2) * (p — dis)) then i get wrong answer on test 9 !! where dis is the distance between the centers of the circles why this happen?

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

Auto comment: topic has been updated by Edvard (previous revision, new revision, compare).

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

Could someone, please, provide a readable piece of code for problem E?

Thanks a lot.

»
9 years ago, # |
  Vote: I like it +16 Vote: I do not like it

E is such a nice task. It can be solved in n sqrt n (with MO alg), n log^2, n log n with centroids,n log n and even n * DSU :P

  • »
    »
    9 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I'd like to learn all of these methods. Could you provide some good links for learning?

    Thanks!

  • »
    »
    9 years ago, # ^ |
      Vote: I like it +16 Vote: I do not like it

    How do you solve it in nlogn and n*DSU?

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

      = solution from editorial with unordered_map.

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

        N log N with no stl cheats is as follows: We'll use smaller to larger technique, but provide merging with no additional log. We'll maintain a vector for each component (it's like find & union) and support O(1) merging for each element in it. (therefore overall merge for 2 components will bo O(smaller)). Well known fact, subtree query could be changed into some preorder array contiguous segment query. This is not important at all, but we can come up with the idea of faster merging — a vertex of a colour X will always be merged first with the nearest vertex of colour X in preorder array. (Left or right, two cases). So we could preprocess for each colour all occurences of it and merge in O(1). Some additional arrays might be needed, but it's the main idea.

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

On task E, if our tree is a line of 10^5 nodes and value is different for each node. For every node we store all different colors in subtree of v in map, and in this case we should use N^2 memory, shouldnt we?

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

Can anyone please explain the statement Let's replace any one of symbols ak with symbol a1, ak - 1 with a2 and so on until the middle of a. Now we have no more than one odd symbol. with sample string bbbcccddd

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

Why does my solution for 600A get TLE? http://codeforces.me/submissions/r4huln/

  • »
    »
    9 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    your solution is O(n square) and the input is too big for n square

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

Can any one tell me what's the difference between __mingw_printf("%Lf") and cout when printing long double?

Here's my solution:

14537257 __mingw_printf

14536996 cout

which first one got Wrong Answer, and the second one got Accepted.

I'm totally confused.

Thanks a lot.

»
9 years ago, # |
Rev. 3   Vote: I like it 0 Vote: I do not like it

Hello, I have a question about Problem D. I fail to hack the solution with the Data like this:

0 0 1000000000
0 0 1000000000

The result should be pi*r^2 = pi*1e18 = 3141592653589793238.46264338. The answer should be at least in this interval:

[3141592653589793238.46263, 3141592653589793238.46265] 

on condition that the absolute error of area doesn't exceed 1e-6. ("The answer will be considered correct if the absolute or relative error doesn't exceed 10 - 6")

That is to say, we should not store pi in 80 or 96 bits long-double variable because we need at least first 24 digits of pi to get correct result for this data. I have checked the output of the code based on long double and confirmed that the absolute error of that solution > 1e-6, but I still got "Unsuccessful hacking attempt". Would you like to tell me the reason?

On the other hand, acosl(-1) = 3.141592653589793238512... here. Only first 19 digits of pi are correct and the absolute error will be about 1 (pi*1e18).

Thanks.

  • »
    »
    9 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Solution can return result with relative error of 1e-6 rather than absolute error of 1e-6.

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

will you add codes for problems?

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

in problem F ..can we extend this solution to general graphs ?

  • »
    »
    9 years ago, # ^ |
      Vote: I like it +8 Vote: I do not like it

    If I am not wrong there is an algorithm to paint in d + 1 colours.

    • »
      »
      »
      9 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      can you provide a link please ?

      • »
        »
        »
        »
        9 years ago, # ^ |
        Rev. 2   Vote: I like it +3 Vote: I do not like it

        Sorry, I was thinking about vertex coloring, whereas in this problem you must color edges.

        • »
          »
          »
          »
          »
          9 years ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          yes i think that should work ! thanks a lot ..but do you have a link for such problem on any online judge ?

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

Can someone explain Make Palindrome using editorial for the case bbbcccddd

  • »
    »
    9 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    cnt[b] = 3 , cnt[c] = 3 , cnt[d] = 3

    all of them are odd so a1=b , a2=c , a3=d

    replace one of a3 characters with a1 so cnt[b] = 4 , cnt[d] = 2

    cnt[c] will remain odd but it is no matter. we can use one c at middle of palindrome.

    so palindrome will be : bbcdcdcbb

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

My code is giving correct output for all the small test cases yet giving wrong answer on test 7 id: http://codeforces.me/contest/600/submission/14548282 can someone tell me where i am missing. I have tried to implement STL.

  • »
    »
    9 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Please someone provide me cases .

    • »
      »
      »
      9 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      your code gives wrong answer on these cases:

      bluespeckisa
      nass
      holewhof
      indsitmorere
      spectfulto
      livelikead
      og
      of
      somefunnyredcoders
      likexell
      os
      butt
      he
      sadtruth
      isxellos
      dontfeelen
      oughfu
      n
      togiveashit
      toth
      ismotherfucker
      bitchandgets
      angrywhenthisblues
      hit
      makesjokesf
      orhisdearm
      aster
      xelloss

      if you want the correct answers for them see here: http://pastebin.com/ZmaE4npq

      • »
        »
        »
        »
        9 years ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Thanks man there was bug in the case where i was handling the even length case. I had always looked at odd cases thinking even case to be perfectly fine but it just came the opposite.

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

Can anyone explain more clearly why the "Small to large" trick reduce the solution complexity to O(n log n) in problem E? Thanks in advance.

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

Where to find theory or some examples related to the small to large technique used in Problem E — Lomsat gelral ?

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

I'm using binary search (http://ideone.com/P63MMj ) in 600B but still get TLE. Any ideas why?

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

    The problem is in Arrays.sort. It uses quicksort and there are anti-quicksort tests in this problem now.

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

For Problem E, can anyone explain "Let's consider some vertex v: every time when vertex v will be moved from one map to another the size of the new map will be at least two times larger." ?

»
8 years ago, # |
  Vote: I like it 0 Vote: I do not like it

In problem E, I understood the technique of Small to Large. But I have one doubt, if all nodes have different colors, won't all the maps take O(n^2) memory?

  • »
    »
    8 years ago, # ^ |
    Rev. 3   Vote: I like it 0 Vote: I do not like it

    I guess I just thought of its logn complexity as a black-box. Now on further thinking, I guess when 2 sets of size s1 and s2 are merged to get a new set of size s3, total memory spaced needed along with the space needed for new set is s3 + min(s1, s2). Moreover, s3 <  = (s1 + s2).

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

    I didnt get the same thing...

»
7 years ago, # |
  Vote: I like it +1 Vote: I do not like it

why solutions are not visible of this round?

»
5 years ago, # |
  Vote: I like it 0 Vote: I do not like it
  • »
    »
    5 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    You have a 2D array which size is N*N, but MAXN = 1e5 => N*N=1e10, but it's too much

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

Could anyone show me a detailed proof or explaination for the reduction of time complexity in problem E.Lomsat gelral when using smaller to larger technique?

Really appreciate for your help <3. I have been contemplating this for nearly a week and still haven't figured stuff out :<.

  • »
    »
    4 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    You need to consider Heavy Light Decomposition of the tree. Number of ancestors of u that traverse u is equal to number of light edges on path from u to the root which is O(log n). Thus, each node is traversed O(log n) times.

»
5 years ago, # |
  Vote: I like it 0 Vote: I do not like it

In problem 4, I am getting wrong ans at test case no. 34 and my ans is off by (.02). But I guess that my way evaluating area kite which is (p*q)/2 where (p is diagonal 1 and q is diagonal 2) is more accurate as it involves less rounded off values. Can it happen that my solution is more accurate than a given solution or please correct me if I am doing anything wrong? Below is the link to my submission:- https://codeforces.me/contest/600/submission/79322952

»
2 years ago, # |
  Vote: I like it 0 Vote: I do not like it

why is the memory complexity not O(n^2)?

Like for example if we have n nodes connected in a straight line and each node has color = index,

then on merging ,each time the parent's map will have one more element than the child's map and sum of elements would be like sum = 1 + 2 + 3 .... + n — 1 + n.

can anyone please tell where i am wrong?