Vladosiya's blog

By Vladosiya, history, 8 months ago, In English

1980A - Problem Generator

Idea: Vladosiya Prepared by: Vladosiya

Tutorial
Solution

1980B - Choosing Cubes

Idea: KwisatzCoderach Prepared by: KwisatzCoderach

Tutorial
Solution

1980C - Sofia and the Lost Operations

Idea: KwisatzCoderach Prepared by: Gornak40

Tutorial
Solution

1980D - GCD-sequence

Idea: myav Prepared by: myav

Tutorial
Solution

1980E - Permutation of Rows and Columns

Idea: KwisatzCoderach Prepared by: KwisatzCoderach

Tutorial
Solution

1980F1 - Field Division (easy version)

Idea: MikeMirzayanov Prepared by: Vladosiya

Tutorial
Solution

1980F2 - Field Division (hard version)

Idea: MikeMirzayanov Prepared by: Vladosiya

Tutorial
Solution

1980G - Yasya and the Mysterious Tree

Idea: Gornak40 Prepared by: Gornak40

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

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

Why is system testing so slow these days?

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

    Because there are so many people participating in contests

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

    I guess it's due to the horrible 150+ tests of problem C... Most solutions took ~500ms on each test, which means that everyone who passed problem C(a large amount!) will take ~75 seconds to be judged

    Sometimes I wonder if it would be better to include anti-unordered data in the pretests. This might help avoid the pointless but time-consuming hack judging?

    • »
      »
      »
      8 months ago, # ^ |
        Vote: I like it -8 Vote: I do not like it

      I guess they shouldn't add all the the hacks to the main test cases. The C problem has 150 test cases but most of them are for Unordered Map. They can try ignoring similar purposed hacks by categorizing them or something.

      • »
        »
        »
        »
        8 months ago, # ^ |
        Rev. 4   Vote: I like it -8 Vote: I do not like it

        Unordered map is constant time right, why is that giving TLE

        Is it because the constant is higher for the test case. Clarify if you can why this code gave TLE 263947136

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

          Yeah so the average case of an unordered map is O(1) for accessing data, but due to collisions the worst case for accessing data is O(N), so the solution becomes O(N^2) instead of O(N). You can read this article- https://codeforces.net/blog/entry/62393

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

          its because unordered_map uses hashing and in worst case hashing haa O(n) time complexity,thats why its giving tle. use map always in place of using unorderd_map

      • »
        »
        »
        »
        8 months ago, # ^ |
          Vote: I like it -8 Vote: I do not like it

        How does one get to know that a test is for unordered map?

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

          Most of these hacks use a pretty standard generator, it is designed/works in a way that it hacks all the solutions using some form of a hash table, be it an unordered map ,unordered set or a python dictionary.

»
8 months ago, # |
  Vote: I like it -8 Vote: I do not like it

C took 100 lines of code for me :(

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

    It could be done in 20 lines ig

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

    Here is a much simpler solution for Problem C.

    int n; cin>>n; int a[n],b[n]; read(a,n); read(b,n);
    int m; cin>>m; int d[m]; read(d,m);
    if(count(b,b+n,d[m-1])==0) no;
    map<int,int> diff;
    for(int i=0;i<m;i++) diff[d[i]]++;
    for(int i=0;i<n;i++)
    {
       if(a[i]!=b[i])
       {
         if(diff[b[i]]==0) no;
         diff[b[i]]--;
       }
    }
    yes;
    

    The last element of modification array has to be present in D. All the elements which are different in B from A have to be present in D as well to carry out the modification. Except for that any other element in D does not matter because you could be changing that element in A to an intermediate number but then you finally change it to what it is in B.

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

      my code is exactly the same, but its giving me TLE at tc9, ig due to unordered_map. edited -yeah so I changed unordered map to simply map and it gave ac, Why is it that map works but unordered map doesnt?

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

E could be easily solved using set of sets: Solution Link

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

testcasesforces

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

can someone explain why only checking the rows is not enough in E.

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

    For example consider the test case of 3×3 Matrix as

    A :

    1 2 3

    4 5 6

    7 8 9

    B :

    2 3 1

    4 5 6

    7 8 9

    We cannot transform A to B using any row or column swaps

»
8 months ago, # |
Rev. 3   Vote: I like it +8 Vote: I do not like it

F is Mike's idea :O

But I think you can't avoid sort so the time complexity can't be $$$\mathcal O(n)$$$.

My sol for F:

Find all corners. Remove all corners and run the algorithm for a second time to get a second group of corners.

A fountain becomes a new corner (after one of the old corners is removed) if and only if:

  • it is among the second group of corners; and
  • it is covered by only one corner.

A corner $$$(u,v)$$$ covers the range {$$$(x,y)|x\in[1,u],y\in[v,m]$$$}.

A fountain becomes a new corner after removing the corner covers it.

It's easy to calculate change of area now.

264008397

(Why $$$\{$$$ -> $$${$$$)

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

    Do you know why my code for F1 doesn't work?

    264033779

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

      You can't find corners correctly in this way.

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

    the time complexity can't be O(n)

    Radix_Sort by ((int64_t)x << 32) | (INT32_MAX - y)

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

    The most important thing was to explain that the part after sorting is linear. (and my memory so short that I forgot about sorting by the end of tutorial)

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

Can any one help me to understand problem c.? And send solution easly

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

    Our goal is to find whether, given a list of sequential operations, an array could be translated into other or not.

    The only operations that matter here are when an element is changed between a[i] -> b[i]. We ensure all such operations (say, d_k) are actually present in d.

    Since d is also sequential, for any successful transformation, all d_k must be present at the end of d. As for a simple solution, kindly refer one from _Runtime__Terror_ a bit above in this discussion.

    Thanks.

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

why I have to remove a[i] in problem d? can someone pls explain with one example.

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

    let b be an array and for each index i in b :b[i] = gcd(a[i],a[i+1]) .

    when you remove a[i] the array a changes => array b changes

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

dang,how much longerr would the system testing go.

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

Can anyone tell me, in C, why dm must be present in b? I read the question 50 times, still didn't understood.

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

    if not , the (index) you apply dm at in the last operation will differ from b[index] as dm != b[t] for any (t) ( if dm is not present in b )

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

    since you have to apply all operations in the order they are given, then dm will always need to be applied last and there is no following operation that can replace it. Therefore it should appear in the final array

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

YES NO forces

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

Can someone explain why my submission 263986368 on problem c got a tle but something like this 263962017 didn't?

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

    same, now i just read that unordered_map with weak hash fxns can cause collisions in testcases and end up in O(n^2), it was safe to use normal map in this problem

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

used unordered map in Problem C and got TLE in system tests and delta changed to -ve.

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

Got hacked on C, i guess its newbie time

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

Need Help!! I am beginner, there are times when i feel my approach is correct based on my intuition but i fail to prove it why, in such cases what should i do, try implementing it in code or give some more time to prove my intuition?

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

problem d, solution 1 — 263972949 failed system test (TLE), solution 2 — 264171599 passed all the tests, code — same in both letter by letter, only difference — solution 1 submitted on Python3 while solution 2 submitted on PyPy3, result — got a "-1" in place of a "+"

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

Problem C solved in C, coincidence or intentional?

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

Can someone explain why my submission 263980440 on problem C got TLE but this submission 264168646 didn't?

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

    count in multiset is briefly O(n)

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

      The time complexity of the count() operation in a multiset in C++ is O(log(n) + k), where n is the size of the multiset and k is the number of occurrences of the element being counted. I think TLE occurs when there is a testcase where k is very large.

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

        Yes, so effectively it is O(n). Got hacked for the same reason T_T

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

E can be done with Zobrist Hashing 264181127.

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

For problem E on the basis of the solution, at the end, after sorting both matrix A and B on the basis of rows as well as on the basis of columns, both should turn out to be equal then only our answer is YES. So to simplify my implementation i took the sum of each rows in A and in B in two vectors and finally after sorting checked if both come out to be same and i did same for the columns also, since the sum property should also satisfy since the numbers are unique but i am getting WA on test 2. Can anyone explain what's wrong with my given implementation. I am not able to think on which test case my implementation will fail. please help 264209981

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

    unique numbers does not guarantee a unique sum. (1,4) snd (2,3) have the same sum value, it is bound to give you wrong answer.

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

came up with a wierd soln for E https://codeforces.net/blog/entry/130129

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

When I submitted problem 3 in the contest it showed accepted but right now it is showing TLE on test 10. Can anyone please explain why does this happen ? It has happened with me once before. (I am new to codeforces, so i don't know about all the rules)

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

    You got hacked. (your code failed system testing) This is probably because you used unordered_map or something in your code. See the note at the end on editorial for C

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

Video Editorial for D

https://youtu.be/O2-wL5OXyYc

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

When is contest rating generally updated after the contest and in how many days editorial of the contest come out?

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

Resources to learn trie?

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

Can someone please tell me the mistakes in my solution to problem E (https://codeforces.net/contest/1980/submission/264239803)? I have used a simple sorting-based method.

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

In problem F2 why the following code isn't giving TLE? What is time complexity of the loop for given problem ?

for(int i = 1; i <= k; ++i){
        auto e = a[i - 1];
        if(ans[idx[e]] == 0)continue;
        int tot = total[i - 1];
        int cr = cur[i - 1];
        int lst = last[i - 1];
        for(int j = i + 1; j <= k; ++j){
            auto ee = a[j - 1];
            if(cr > ee.y){
                tot += (cr - 1) * (lst - ee.x);
                cr = ee.y;
                lst = ee.x;
            }
            if(ans[idx[ee]] == 1){
                ans[idx[e]] = tot - total[j];
                break;
            }
        }
    }
  • »
    »
    8 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    The complexity is k^2 which obviously TLEs for k <= 2*10^5

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

      That was accepted. But now I got it why. Because we are only checking points between corners the time complexity will be O(n).

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

D was talking about removing i-1 i or i+1 then why is it removing the from 0 to i or 0 to i-1 or 0 to i+1. If it is works the same then can someone explain me how?

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

In Problem E: Suppose for all those test cases which have the answer "YES", we are also asked to output the possible actions (not necessarily the minimum) in the form: i) r a b -> swap row a with b. ii) c a b -> swap column a with b. Then, what would the approach be for this one?

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

    Good idea! I still confused this way , which found a deatialed path to transform matrix B , from contest time to now.

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

Problem E is flexible and great mind!The Tuorial only introduce solved way.It's so upset>_<.Can Anyone explain that detailed the reason of way >_< ?

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

    you can check mine it is relatively easy i first checked row wise. there i made a map for every row after sorting it and then checked for every sorted row in b if it existed in the original map. If it doesnt exist then no() else we check further .similarly for columns https://codeforces.net/contest/1980/submission/264333535 .

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

      Thank you for your reply! I incline to figure out how transform A into B , such as proof. The tutorial is understood by me , but i still don't why , specifically.

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

      I used multiset , which is slower than your way. I think your idea better than mine!

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

can someone explain the editorial code of C

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

Editorial code for C can also be hacked because qsort worst case is $$$O(n^2)$$$: https://codeforces.net/contest/1980/hacks/1033165

Code

Unexpected verdict means that one of the solutions marked on Polygon as Correct can't pass this test. Vladosiya Gornak40

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

I have no ideas why I got wrong answer on problem G: https://codeforces.net/contest/1980/submission/264341580. My solution is the same as editorial.

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

Can somebody explain why it doesn't give TLE? I tried fixing each using rowswap and colswap and checked in the end if both matrices are equal or not. Submission

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

I am calculating that same sum of row and columns present in the array B or not

https://codeforces.net/contest/1980/submission/264546235

I am unable to find where it is failing. Can you tell some test case where it fail.

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

    I don't think sum is an ideal hashing method.

    1
    2 3
    1 2 3
    6 4 5
    
    1 2 3
    5 6 4
    

    Read YES, expected NO.

    Hope it helps:)

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

264169959

why it is giving wrong answer for problem D.

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

Can anyone help why my code for 1980G - Yasya and the Mysterious Tree is not working?

264619004

264609607

I am happy if any of the above two works.

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

in problem E I have reached till a point that I want to check if one vector is a permutation of another and all of them must be shifted the same amount is this correct or just give up

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

A O(nm) solution for E that uses xor hashes:

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

In G why do you need to remove the x[a] first in order to get the result?

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

can anyone point out what went wrong in my code problem c ;

include <bits/stdc++.h>

using namespace std; int original[210101] ; int found[210101] ; int diffs[210101] ; int modifier[210101] ; int main() { int t ; cin >> t ; while (t--) { int n ; cin >> n ; for (int i = 0 ; i < n ; i++) cin >> original[i] ; ///// int j = 0 ; for (int i = 0 ; i < n ; i++) { cin >> found[i] ; if (original[i] != found[i]) { diffs[j] = found[i] ; j++ ; } }

int m ;
    cin >> m ;
    for (int i = 0 ; i < m ;i++)
        cin >> modifier[i] ;
        /////////
        int hero = 0 ;
        for (int i = 0 ; i < n ; i++)
        {
            if (found[i]==modifier[m-1])
            {
                hero++ ;
                break ;
            }

        }
        sort(modifier , modifier+m) ;
        sort (diffs , diffs + j) ;
                int k = 0 ;

    if (hero==0)
            cout << "nO" << endl ;
    else
    {
        for (int i = 0 ; i < m ; i++)
        {
            if (modifier[i]==diffs[k])
                k++ ;
                if (k==j)
                    break ;
        }
    if (k==j)
        cout << "YES" << endl ;
    else
        cout << "NO" << endl ;
    }

}
return 0;

}

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

Did someone solve problem G using Centroid Decomposition?

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

Solved E via union find, was way more intuitive for me, but basically the same concept as AC.

Submision: 265923059 https://codeforces.net/contest/1980/submission/265923059

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

can anyone tell any testcase where my code fails? (https://codeforces.net/contest/1980/submission/266299334)

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

Solution to problem E using the least amount of memory: https://codeforces.net/contest/1980/submission/267825080

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

Editorial solution to problem F2 is $$$O(k \log k)$$$ in the general case, but degenerates to $$$O(k^2)$$$ in the worst case (i.e., when all fountains are corners). Here's a truly $$$O(k \log k)$$$ solution: https://codeforces.net/contest/1980/submission/267832408

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

    Editorial solution checks only the fountains between each two corners, and it never checks same fountain twice. In case of all fountains are corners then second loop immediately terminates (as the next fountain is corner). So, overall complexity is $$$O(K)$$$

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

      That may be true, but we must not forget that the fountain locations are being sorted as a first step, and this takes at least $$$O(k \log k)$$$.

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

        Oh yes, that's true. But I only mentioned the part which causes the complexity to be $$$O(K^2)$$$. But, The overall complexity of the whole code is obviously $$$O(K\log{K})$$$. And also small note, Sorting takes at most $$$O(K \log{K})$$$, not at least, as it indicates the worst complexity.

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

Solution to problem D using zero extra space: https://codeforces.net/contest/1980/submission/267978668

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

Well, problem C's hacks are extraordinary. Even the author's code gets Time Limit Exceeded on test 156.

»
5 weeks ago, # |
  Vote: I like it 0 Vote: I do not like it
def check(element):
    if len(element[0]) == 1:
        return "YES"
    else:
        lst_column = []
        for i in range(len(element)):
            lst_column_element = []
            for k in range(len(element[i][0])):
                sum = 0
                for j in range(len(element[i])):
                    sum += element[i][j][k]
                lst_column_element.append(sum)
            lst_column.append(lst_column_element)
        lst_row = []
        for i in range(len(element)):
            lst_row_element = []
            for j in range(len(element[i])):
                sum = 0
                for k in range(len(element[i][j])):
                    sum += element[i][j][k]
                lst_row_element.append(sum)
            lst_row.append(lst_row_element)
        if sorted(lst_row[0]) == sorted(lst_row[1]):
            if sorted(lst_column[0]) == sorted(lst_column[1]):
                return "YES"
            else:
                return "NO"
        else:
            return "NO"
    pass
if __name__ == "__main__":
    number_testcase = int(input())
    matrix = []
    lst = []
    for i in range(number_testcase):
        n, m = map(int, input().split())
        if m == 0 or n == 0:
            lst.append("YES")
            break
        elements = []
        element = []
        for j in range(n):
            element.append(list(map(int, input().split())))
        elements.append(element)
        element = []
        for j in range(n):
            element.append(list(map(int, input().split())))
        elements.append(element)
        matrix.append(elements)

    for i in matrix:
        lst.append(check(i))
    for i in lst:
        print(i)

can anyone explain that my code wrong at what testcase plz, my idea is check the sum of all columns first and sort it, if two matrices are the same then I check the row same way as columns.

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

In problem C, will anyone explain why is it necessary to presence of dm in b? I mean if it is not present then we can assign it to some value which is already present then it will be overite?