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

Автор atcoder_official, история, 9 месяцев назад, По-английски

We will hold AtCoder Beginner Contest 349.

We are looking forward to your participation!

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

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

Good luck to everyone!

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

GLHF!

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

Instresting survey.=)

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

why a different scoring distribution?

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

GLHF & Guess

Good :
OK, not bad :
Bad :

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

GLHF!

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

Hope Everyone one got a AK!

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

GLHF!

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

GL&HF!

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

was f related to sos dp?? how to solve f??

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

    Consider the way of computing LCM by taking the maximum of exponents in prime factorization. For example, LCM(2335,2431)=2max(3,4)3max(5,1). Factorize M and compute numi=primeexponentii in M. If some ai does not divide M, we can ignore ai (the exponent of some prime is bigger in ai than in M). For each ai that divides M, let's assign a bitmask to it. The j-th bit will be on if numj divides ai. If it does not divide, it means that ai has a lower exponent on this prime that in M, so choosing ai in a subsequence won't contribute into getting LCM = M in this particular prime. Note that this mask will have at most 13 bits. So now your problem is: given some bitmasks, count in how many ways you can choose a subset of these bitmasks such that their bitwise OR is equal to the complete bitmask. We can do this with DP. dpmask = how many ways there is to choose a subset of bitmasks to form mask. This can be done by iteratively considering each bitmask, for a total of O((2k)2), where k=13. Submission

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

What is any adequate time complexity solution to F? How to solve it in any way other than fucking constant optimizing O(d(m) * 2^P) (where p is nr of distinct prime divisors of m)?

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

    upd: why would you allow factorizing in O(sqrt(1e16))?

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

    I did it in O(4P) xd

    upd: as for factorization, i copied fastest code on Library Checker.

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

      yeah, after reading others' codes already realized it was possible

      which, however, raised question about why would anyone intentionally set such constraints for M if factorizing in O(sqrt) was intended

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

        most probably because then there can be at most 13 distinct prime divisors for m, then that will cut off some unintended solutions? idk

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

        my code takes 300ms, 1e8 really isnt a lot of operations.....

        they set such constraints to allow sqrt factor but not allow O(4^p) [it didnt work tho ig, sad]

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

          I believed 4^p can't work slower than 1e8 operations with modulo...

          Was wrong sadly :D

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

            oh 4^p isnt intended though? i have 3^p

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

              it can be solved in O(132×(213)) by fast mobius transform indeed, and the other bound is checking all divisors of M in ai.

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

How can I see the testcases? When will it be available in this link https://www.dropbox.com/sh/nx3tnilzqz7df8a/AAAYlTq2tiEHl5hsESw6-yfLa?dl=0

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

Can anyone please explain the solution of F-Subsequence LCM.

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

Can anybody tell why does this submission https://atcoder.jp/contests/abc349/submissions/52354451 TLE?

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

I think I did something wrong since I can't understand second the example of pE. Let's say Takanashi chose {1, 1}, {1, 3}, {2, 1}, {2, 2}, and {3, 2} (1-based, define the top-left corner as {1, 1}), than it's a draw. He got -1 +0 -4 -2 -1 = -8 points, while Aoki got -13 points, how can the answer be Aoki?

btw can we really define " play optimally for victory" ? In real world, we'll think much. For instance, we try to avoid our opponents from getting an " L-shape ".

Answers by brute force will keep every possibilities that is a draw, including the unreasonable ones.

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

F could be solved with PIE and bitset in O(m+2knw) (k=13 here)

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

And there is an easy greedy solution for G:

Lets iterate i from 1n:

  • If position i is covered by previous positions (i.e. there exists j that j+aj>i), then we already know si. Then, add a constraint si+ai1siai+1.
  • Else, find the smallest number x that satisfying all constraints and let si=x. Then add a constraint si+ai1siai+1.

It is not hard to prove that if the solution exists, we can find the smallest one by this.

How to check if the solution exists? We can simply run a manacher to check it.

Time complexity : O(n).

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

    My idea is completely different.
    My solution was an extension of my submission of 103388L - Listing Passwords

    My idea was as follows -
    We create a DSU size 2N.
    Nodes in the same component denote that values at those places are same.
    We start by merging i and 2Ni1 in DSU.
    Now, S[L,R] is a palindrome if SL=SR, SL+1=SR1, SL+2=SR2, and so on...
    Let U=L and V=2NR1
    Because of the above merge nodes, we can also merge U+i with V+i for each 0iRL

    Doing this natively with just one DSU will lead to TLE.
    So, we maintain logN DSU.
    If L and R are in the same component in i DSU. It denotes, (L+j,R+j) are in the same component for each 0j<2i.
    We can split (U+j,V+j) merging into O(logRL+1) different merges of sizes of powers of 2.

    At last, if any conflicting pair is in the same component we print NO. Otherwise, the answer is YES.
    We can greedily find an assignment for YES.
    My submission

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

    great solution, i was trying to do something like this only but rather than checking this(there exists j that j+aj>i) i was trying to greedily put choose si and then choose all j such that j>i && j-aj<=i, but could not think of quick way of doing it, you solution is good.

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

could somebody help why this submission WA or provide a test case for problem F?
https://atcoder.jp/contests/abc349/submissions/52362844

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

void yes() { cout<<"Yes\n"; } void no() { cout<<"No\n"; }

int main(){ ios_base::sync_with_stdio(false); cin.tie(NULL);cout.tie(NULL); string S; string T; cin>>S>>T; int val=0; string t=to_lower(T); for(auto x:t){ size_t pos=S.find(x); if(pos!=string::npos){ val++; } } if(val==3||(val==2&&(T.back()=='X'))) yes(); else no();
return 0; }

anyone please what's wrong in this can't figure it ?? Problem C .

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

Can someone tell me where I went wrong ? https://atcoder.jp/contests/abc349/submissions/52354647

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

why in problem D always taking the largest power of two that divides works? Any proof?

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

When will the official editorials be translated into English? Youtube is prohibited in Chinese Mainland..