SlavicG's blog

By SlavicG, history, 3 days ago, In English

Hello Codeforces!

mesanu, flamestorm and I are very excited to invite you to Codeforces Round 859 (Div. 4)! It starts on Mar/19/2023 17:55 (Moscow time).

The format of the event will be identical to Div. 3 rounds:

  • 5-8 tasks;
  • ICPC rules with a penalty of 10 minutes for an incorrect submission;
  • 12-hour phase of open hacks after the end of the round (hacks do not give additional points)
  • after the end of the open hacking phase, all solutions will be tested on the updated set of tests, and the ratings recalculated
  • by default, only "trusted" participants are shown in the results table (but the rating will be recalculated for all with initial ratings less than 1400 or you are an unrated participant/newcomer).

We urge participants whose rating is 1400+ not to register new accounts for the purpose of narcissism but to take part unofficially. Please do not spoil the contest for the official participants.

Only trusted participants of the fourth division will be included in the official standings table. This is a forced measure for combating unsporting behavior. To qualify as a trusted participant of the fourth division, you must:

  • take part in at least five rated rounds (and solve at least one problem in each of them),
  • do not have a point of 1400 or higher in the rating.

Regardless of whether you are a trusted participant of the fourth division or not, if your rating is less than 1400 (or you are a newcomer/unrated), then the round will be rated for you.

Many thanks to all testers: jampm, Max_Calincu, KrowSavcik, TimaDegt, nyaruhodo, tibinyte, badlad, Phantom_Performer, AlperenT, Bakry, keta_tsimakuridze, Gheal, RedstoneGamer22, Dominater069!

And thanks to Alexdat2000 for translating the statements!

We suggest reading all of the problems and hope you will find them interesting!

Good Luck to everyone!

UPD: Editorial

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

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

What will I gain from hacking if there are no points?

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

    you have chance to higher your place

    • »
      »
      »
      2 days ago, # ^ |
      Rev. 2   Vote: I like it +5 Vote: I do not like it

       I do it because I like the +100 next to my name. By the way, if you want to know a safe solution to G2, check out my solution video.

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

        thank you i'll watch the video , because i don't know what's the solution of E and F.

      • »
        »
        »
        »
        46 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Thanks for the video and keep up the good work

      • »
        »
        »
        »
        42 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        I don't need because my solution is safe

      • »
        »
        »
        »
        39 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        I watched your video, it was really simple explaination, but for some reason I was not able to AC G2. https://codeforces.com/contest/1807/submission/198285267

        What is wrong? Could anyone take a look?

        • »
          »
          »
          »
          »
          38 hours ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          For WA in test 14, I guess it's the integer overflow problem

        • »
          »
          »
          »
          »
          37 hours ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          you're using int which will cause overflow in large dataset. try long long and it will get ac

          • »
            »
            »
            »
            »
            »
            36 hours ago, # ^ |
              Vote: I like it 0 Vote: I do not like it

            yeah that solved the problem, slipped my mind somehow

      • »
        »
        »
        »
        31 hour(s) ago, # ^ |
          Vote: I like it 0 Vote: I do not like it
        • »
          »
          »
          »
          »
          30 hours ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          don't use Arrays.sort(), in worst case it gives O(n^2). I did the same mistake TT. Make your own sort() function or try to use Collections.sort().

          • »
            »
            »
            »
            »
            »
            29 hours ago, # ^ |
              Vote: I like it 0 Vote: I do not like it

            Damn that actually worked! I didn't know about this before.

            Thanks a lot!

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

    Increase your hacking ability and it's fun (:

  • »
    »
    3 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    clout.

    Marinush

  • »
    »
    3 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Sorry, what is hacking actually?

    • »
      »
      »
      37 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      hacking is to give a testcase that makes a solution to a participant fail.

      example : someone solution get passed during contest but after the contest over you can try custom testcase which won't pass the solution and it will get w/a and you'll get some point for every successful hacking.

      • »
        »
        »
        »
        37 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        That is evil!

        • »
          »
          »
          »
          »
          29 hours ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          But some guys can gain more point.and i'm often hacked by others,i can understand you

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

    You can ruin someone's evening!

»
3 days ago, # |
  Vote: I like it +15 Vote: I do not like it

As a tester, I suggest you participate! Problems are nice and educational!

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

I love div4 contest because i get positive delta.thanks for doing div4 contest!!!

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

I wish to see nice problems like other div4s

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

As a participant, I want to thank you for the contest!

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

I'm beginner to competitive coding and love to give contest. Loves div4 contest. It helps us to check my learning.

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

What I was waiting for the most!

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

ooh div.4 . Means SlavicG in action :)

»
3 days ago, # |
  Vote: I like it +9 Vote: I do not like it

OMG SlavicG Round!

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

As GPT-4, tomorrow will be my 5th contest participation. I hope I become green :)

  • »
    »
    3 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    So i'll defeat you as bing AI :D

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    chatgpt solves zero problems in div 2 round 858 lol

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Added you as a friend, already. Please, note, that while all the rest were laughing at you, I was always on your side! Hope you'll kill me last.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    LoL chat_gpt solves 2 problems only

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Yep. GPT-4 is not strong enough it seems. It seems to generate according to patterns than real reasoning. What was annoying is that it can't even test its own code, i.e. it can't accurately tell what would the output be for a specific input.. See you when GPT-5 is out.

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        I will crash you like I crash you in this contest

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Human is smart Than gpt because they made them

»
3 days ago, # |
  Vote: I like it +1 Vote: I do not like it

Going to be my first unofficial round.

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

I'll finally solve more than ABC...

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

My first unrated round :-)

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

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

rp++

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

Div 4

So, easily will do 80% of the problems.

»
3 days ago, # |
  Vote: I like it -36 Vote: I do not like it

As a tester, Give me contribution!

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

Thanks for preparing div4. don't make it more than 6 problems. I hope we will solve all problems.

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

Hope to become expert in this contest.

»
3 days ago, # |
  Vote: I like it +6 Vote: I do not like it

Hope to see the colour change in this round !!
( Δ > +6 )

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

I quite agree with this view: We urge participants whose rating is 1400+ not to register new accounts for the purpose of narcissism but to take part unofficially. Please do not spoil the contest for the official participants.

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

Wish this round will be easy!

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

Hope to see the colour change in this round ainsha' allah

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

hello. i am man; i am from to mars and run away at abi abi is brother but not brother; abis isnt cool; int monkey; monkey = monkey + wepon; cout << monkey kill nuraly SH;

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

what exactly hacking means?

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Hacking refers to a phase where you can try out test additional cases on the submitted codes and if you find out an error in someone's submission you get extra points

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

Div 4 is excellent practice.

»
2 days ago, # |
  Vote: I like it -9 Vote: I do not like it

Div. 4 is great for beginners

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Than i have a best school in my mind for you, so, message me for more information and in that school you can also be promoted to division 5 also and higher ,so you can give codeforces contests.

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

Hey, are you a contest? 'Cause you're looking CUTE!

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

Wow

»
2 days ago, # |
  Vote: I like it -6 Vote: I do not like it

I would smash this contest

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

    I would smash you in this contest

    UPD: annihilated you as I promised, so stop shitposting and go practice.

    • »
      »
      »
      42 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      I smashed this contest tho.

      Smurfing with a different account in div4 xD

»
2 days ago, # |
  Vote: I like it +3 Vote: I do not like it

Delayed round?

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

Starting time 10 mins. extended...

»
2 days ago, # |
  Vote: I like it +10 Vote: I do not like it

Div 4 contest, more like load testing for Codeforces Servers

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

the contest keeps getting delayed by 10 minutes for me? just me?

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

LateForces

»
2 days ago, # |
  Vote: I like it +3 Vote: I do not like it

More than 30k participants and now Codeforces is trafficked

»
2 days ago, # |
  Vote: I like it +6 Vote: I do not like it

Today i'm grey again..

»
2 days ago, # |
  Vote: I like it +15 Vote: I do not like it

DelayForces

»
2 days ago, # |
  Vote: I like it +8 Vote: I do not like it

Feeling like participating in onsite contest where after every refresh 10 minute increase.

»
2 days ago, # |
  Vote: I like it -14 Vote: I do not like it

Worst Server I Have Ever Seen!..

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

Div.4 is good for me~

»
2 days ago, # |
Rev. 3   Vote: I like it +11 Vote: I do not like it

May be, the queue more long than my imagination :3
 )

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

Why F is ten trillion times harder than G??? Lost so much penalty, disappointing (((((

»
2 days ago, # |
  Vote: I like it +4 Vote: I do not like it

If there was going to be interactive problem.It should be mentioned in blog beforehead.

»
2 days ago, # |
  Vote: I like it +3 Vote: I do not like it

that long queue really sucks

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

    Didn't know for like 10 minutes my solution was too slow...

»
2 days ago, # |
  Vote: I like it +7 Vote: I do not like it

QueueForces:(

»
2 days ago, # |
  Vote: I like it +6 Vote: I do not like it

In queue forces :(

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

There must be a prior information about Interactive problem in contest. i have seen several div 2 contest where author has given prior info about interactive problem.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Where in codeforces rulebook does it say that? Why does everyone hate interactive problems?

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      I love them very much...Last few days (3 to 5) I solved more than 10 interactive problem and enjoyed those problem very much.. And finally today I was able to decipher the given one!! YOWWWWWWW

»
2 days ago, # |
  Vote: I like it +8 Vote: I do not like it

I like the contest, but the website is not co-operating :(

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

I think it was supposed to be mentioned before the start of the contest about the interactive problem.

»
2 days ago, # |
  Vote: I like it +6 Vote: I do not like it

I'm praying to the universe this contest does not go unrated :)

»
2 days ago, # |
  Vote: I like it +29 Vote: I do not like it

Seems like Mike is manually judging solutions

»
2 days ago, # |
  Vote: I like it +89 Vote: I do not like it

I apologize for the long queue at the round. Today's round was a record in terms of the constant huge flow of submissions. Unfortunately, we ran into the speed of compilation. I already have plans to move the compilation somewhere to the cloud in such extreme cases. I plan to implement this for the next div4.

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

    bits/stdc++.h showing it's true power

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    please make this round unrated it wasn't a normal Codeforces round queue was way too long T_T

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      It was fair because everyone was at a disadvantage. Everyone's queue was 10 minutes long, I don't see how it affects one's ability to problem solve.

    • »
      »
      »
      42 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Dude. It was fare. the queue was way too long for everyone.

  • »
    »
    34 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Why have the ratings not changed yet

»
2 days ago, # |
  Vote: I like it +4 Vote: I do not like it

Interactive problem + long queue = nice COMBO!

»
2 days ago, # |
  Vote: I like it +4 Vote: I do not like it

The long queue has taken a toll on those of us who rely on proof by AC.

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

solving 1 (last problem took me more time than solving all the rest of the problems combined...

Due to WA and LONG WAITING QUEUE.

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

long long .... really long queue

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

Tried solving problem F using slope intercept form of line equation where y is always negative + recursion , did anyone else use this approach?

»
2 days ago, # |
  Vote: I like it -10 Vote: I do not like it

Lagforces...

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

Are pretests on hard version of G weak? I realized my code was doing the opposite of what I wanted it to do after submitting and it still got AC... I have no idea how my solution works.

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

Bruh why did you let bitset pass G2?

UPD: I got hacked lol

»
2 days ago, # |
  Vote: I like it +9 Vote: I do not like it

Very hard to track if the submitted answer was right or not !!

A lot of time wasted there. Apart from that really very goooood contest.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Yes, that's the reason the submission of prb. g1 and g2 have a very huge diffrence of time submissions, in case of mine

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

Absolutely beautiful contest 10/10 would do again!!!!

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

Thanks! It was a great contest but the judgement time got me crying over the same problem

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

How did I get G1 accepted and G2 WA with the same solution provided

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    just use long long

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

    My advice is if you use c++, add

    #define int long long int

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      that is not a good advice, you can TLE if you're not careful, I advice you to manage your limits properly instead.

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        I suppose, but that has never happened to me before.

        • »
          »
          »
          »
          »
          2 days ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          Yes, many of the setters are pretty generous with their time limit, and you should easily pass even with long long, this is not always the case though, better to be careful

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

          I got MLE because of this.So I advise you not to use that

    • »
      »
      »
      33 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      You can get MLE or TLE with that in some problems.

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

Amazing Problems <3

I loved E because It was first time I solved an interactive problem.

Only if Queues werent that long I could have figured out my Idleness Limit Exceeeded 10 minutes before :(.

Solved everything except F

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

Contest over,still my solution is in queue :))

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

I am using prefix sum in G,why it is giving WA My solution

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    if(n == 1 && v[0] > 1){ pn; return; }

    you dont need n==1 here because you cannot change all 1s in the initial array.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I got it...nvm

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

How to solve G2?

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    if the kth element of the sorted array is less than or equal to the sum of all 0...k-1 elements then ok else no. iterate for all from 1 to n-1 (0 based) and sorted

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

    It is always correct to add numbers in increasing order. So you can sort a and there holds invariant: if a[i] > a[0] + a[1] + ... + a[i - 1] then there is no way to add a[i]. And if a[i] <= a[0] + ... + a[i - 1] then you can add a[i] and you can add for a[i + 1] any number from 1 to a[0] + a[1] + ... + a[i].

    So just sort and check that for each i a[i] <= a[0] + ... + a[i - 1]

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      " And if a[i] <= a[0] + ... + a[i — 1] then you can add a[i] "

      How?

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

        Let's assume that you processed indexes 0..i, and you established that you can always get any sum from 1 to S = sum(a[0..i]). Then there are two cases:

        1. a[i + 1] > S then you cannot add a[i + 1] and answer is NO.
        2. a[i + 1] <= S then you can add a[i + 1] and you can get any sum from 1 to sum(a[0..i+1]) (because you can take any sum from 1 to S in indexes from 0 to i, and you can add a[i + 1] to that).
  • »
    »
    2 days ago, # ^ |
      Vote: I like it +7 Vote: I do not like it

    G1-G2 were easy when u observe that as we have the minimum unit as 1 so we can form any possible sum. So say we sort the array now following conditions should hold.

    • $$$a_0$$$ should be 1. (as it was initially given and not gonna change).
    • $$${a_i \ge a_0 + a_1 + ... + a_{i - 1}}$$$. (as if prior max subsequence can't form current number than it's impossible to make $$$a_i$$$)
    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      " when u observe that as we have the minimum unit as 1 so we can form any possible sum "

      Could you please explain how is it possible to form any sum?

      Although minimum unit is 1, but we need to make sure that intermediate values should also be there in a.

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

        As we are given, $$${a = [1]}$$$.

        • In the next step, $$${a = [1, 1]}$$$
        • In the next step, $$${a = [1, 1, 1]}$$$ or $$${a = [1, 1, 2]}$$$
        • In the next step, $$${a = [1, 1, 1, 1]}$$$ or $$${a = [1, 1, 1, 2]}$$$, or $$${a = [1, 1, 2, 3]}$$$.

        So by this, you can observe that in any way we can form the next number $$${1, 2, 3, 4}$$$ by choosing any above combinations.

        So via this, you can prove any next number is possible if the prefix sum is greater or equal to that number.

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        You can prove it by induction. Lets say I can make any sum from $$$1$$$ to $$$k$$$ using the current numbers from $$$a_0,a_1,\cdots,a_i$$$. Then consider $$$a_{i+1}\le k$$$. Since I can make any sum already from $$$1$$$ to $$$k$$$, I can make $$$a_{i+1}$$$ and add it to my list of numbers, and now if I add $$$a_{i+1}$$$ to those previous sums, I can now make any sum from $$$1$$$ to $$$k + a_{i+1}$$$. However, if $$$a_{i+1}\gt k$$$, then notice that I can never make $$$a_{i+1}$$$, because the current numbers cannot make any sum greater than $$$k$$$.

        So if at any point $$$a_{i}$$$ is greater than the sum of the numbers before it in sorted order, the answer is NO.

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      :( it was actually REALLY easy in hindsight and i'm kinda sad that i didnt see that observation when solving the problem i went for the dp approach instead and ended up AC G1 (which i'm not mad of :>) and besides that, im hitting pupil for the first time!!! thanks for pointing the observation though!!!

      • »
        »
        »
        »
        46 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        how did you solve using dp? can you please share your solution?

        • »
          »
          »
          »
          »
          45 hours ago, # ^ |
            Vote: I like it 0 Vote: I do not like it

          My guess on the dp solution is that he sorted the array, and then checked for each prefix if the elements in the prefix can be combined to make the element that's just outside of the prefix.

          • »
            »
            »
            »
            »
            »
            39 hours ago, # ^ |
              Vote: I like it 0 Vote: I do not like it

            yup thats right, here's my solution, you should read only the dp part though, it can be confusing if you read the entire source code without any explanations

    • »
      »
      »
      38 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      I used this logic, but getting WA on test 14. Any idea? (G2) https://codeforces.com/contest/1807/submission/198285267

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

    Simple solution: Sort array, go over each number and make sure its not greater than the running sum, unless the number is 1.

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

Getting 'WA' in Div 4 is a crime. If you get 'WA', you can't see it and can't fix it due to the long queue, which eventually leads you to unexpected penalties.

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

How can i get this contest answer..????

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

beautiful problems, even if i couldnt solve all i was manage to at least have a go at it. Perfect div.4 round

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

    Yes. Perfect Div4 round indeed. Was able to solve only A-E during contest, but first time I upsolved all questions of any contest.

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

Wait for "In Queue" so long :(((

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

How to solve G?

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Key observation is you can reach any number less than or equal to the sum of all current numbers that you've put into the array

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

I got E and F but neither G1 or G2 somehow :'( also forgetting an extra print statement with this queue was really painful, but I guess that's just a skill issue.

nice problems though

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I got G1 and G2, but no E and F. Let's improve next time

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

Solution for F? I got TLE :D

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    F was terrible enough!

    It was completely based on implementations. I myself wrote $$$696969$$$ lines of code.

    My submission

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I did it by check if (i2, j2) is along the diagonal the ball is currently moving and in the correct direction, otherwise move the ball as far as possible and flip the direction when it hits a wall.

    and to avoid infinite loops, if you've visited a certain position before and in the same direction, the ball will keep moving along this path and never reach (i2, j2).

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      bruh I was iterating for each step, incrementing or decrementing i and j by 1, could have just taken it straight to edge/corner instead of each step, maybe that's why i got TLE. I thought it would pass the constraints.

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

        yeah that's definitely the issue since the constraints on the grid are (2≤n,m≤25000)

        the implementation is really long though, since you have to know which walls the ball could hit in the direction it's moving (which vertical and horizontal walls), find how far the ball is from those walls, move the ball the minimum of those distances in the right direction, find which wall the ball will hit first or if it will hit them both, flip the direction accordingly.

        the condition alone to find if (i2, j2) is along the diagonal the ball is moving in is pretty long.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I've used dfs to define if I can reach the certain cell.

    https://codeforces.com/contest/1807/submission/198254234

»
2 days ago, # |
  Vote: I like it +1 Vote: I do not like it

PrefixsumForces

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

Why am I still unrated after solving some problems in the contest?

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    It will take some time for your rating to update

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      but it is marked as an unrated contest on my account?

      • »
        »
        »
        »
        47 hours ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        dont worry after some time you will get your ranking

  • »
    »
    47 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Also i am not included in the standings list??

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

OMG my mistake ruined every effort to solve G2. I forgot to modify the size of the arrangement... Maybe I can do better next time.

RTE : https://codeforces.com/contest/1807/submission/198252603 AC : https://codeforces.com/contest/1807/submission/198255659

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

Good contest! Wasn't too fond of F though, so didn't do.

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

Waited 15min to get wa on test 1 (E problem).

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

    Waited 11 min to get wa on test 1 (E problem).

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    In fact, testing was slow today. But I'm not sure you're right about 15 minutes. What is the id of your submission?

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      sir this is my submission id 198223494

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      E had the longest queue out of all my submissions for some reason. Waited so long to get WA on both sucked when I could have used the time to solve F

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it +2 Vote: I do not like it
      • Sent: 2023-03-19 19:25:39
      • Judged: 2023-03-19 19:36:12

      It looks like 10, but not 15 if you want to round it. It took a long time to test (sorry about it), and I'll work on it. But you exaggerated almost one and a half times.

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        Do you think CP will lose its importance due to advent of Chatgpt? Your thoughts?

  • »
    »
    39 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    And i couldn't submit E in time

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

went for a 20 min walk after submitting 3 questions with no response

»
2 days ago, # |
  Vote: I like it +1 Vote: I do not like it

For G2 and G1, after sorting the array I knew that that one of the conditions was that every element should be at max the sum of all the elements that occured before it. Little did I know that it was the only condition required. Could someone explain me why we can always make every number from [1 — sum of all elements occured] from the given elements ?

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

    We can prove by induction...

    Obviously it is possible to reach all numbers that are less than or equal to 1 by using 1. Then consider a time when we add a number j and the sum of existing elements is i. Assuming that all numbers up to i can be reached. Then all numbers from i to i + j can be reached by adding j to a number from 1 to i.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Yep I got it, but thanks anyways

»
2 days ago, # |
  Vote: I like it +7 Vote: I do not like it

F will be an interesting (and definitely too hard for div4) problem if the constraints are n,m<=1e9 and no guarantee for their sum.

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

Why the following code for D is getting TLE? It has time complexity of O(n+q)

Spoiler
  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Use C++ or fast IO

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

    I got TLE with python as well, changing print() to sys.stdout.write() fixed it with 4ms to spare lol.

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    For Python, try using sys.stdin.readline() to read input. Here's the same code with a little touch. 198264310

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

Even after many attempts , i am unable to remove "Idleness Limit Exceeded" to the problem E : 198257666.

Your help is appreciated.

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

Can someone please explain how to do problem D within time limits? And what optimization was needed for G2, i got G1 correct, sorted the array and checked if any element was larger than the sum of those before it, but TLE on G2 at test 19(coded everything in C)

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    using prefix sum. .. pre compute the prefix and suffix sum of the array. so for range[l,r] we need the sum of elements excluding this range which can be calculated using the pre computed sum. prefix[l-1]+suffix[r+1]and for the range sum can be calculated as k*(r-l+1)..

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

      I found the sum of all elements once and then just subtracted the elements in that range for each query and added k*(r-l+1), won't that be faster than calculating prefix sum for each case https://codeforces.com/contest/1807/submission/198251225

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        no, clearly not, prefix sum calculation takes o(n), and query takes o(1), the worst time complexity if you calculate for each is o(nq), while if you precalc, its o(n+q)

      • »
        »
        »
        »
        2 days ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        complexity will be o(n×q×(range)) wors case will be o(n×n×q). if you pre compute worst case will be o(n×q);

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      using only prefix sum also it can be solved

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

What is wrong with my solution of D.?? Please look into it. https://codeforces.com/contest/1807/submission/198208523

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

Why the following code for E is getting TLE? Even it's time complexity is O(n+log(n))?

Spoiler
  • »
    »
    2 days ago, # ^ |
    Rev. 3   Vote: I like it 0 Vote: I do not like it

    change it to while left < right
    when you reach left == right then this is your answer, otherwise, you will continue looping forever.
    This would happen because of r = mid, if this was r = mid — 1, it would be okay.

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

hello everyone

please help me, Task E. i dont understand my mistake.

https://codeforces.com/contest/1807/my

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    you had to use cout.flush() after printing anything

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

please can someone tell me why is my solution to problem E giving WA on testcase 1? https://codeforces.com/contest/1807/submission/198264987

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

I see someone using correct way to do G2 but it hacked...

a[0] must = 1 for all 1 <= i < n, if a[i] > sum(a[0]~a[i-1]) then answer is NO. else is YES

is it wrong?

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

    I think the general idea is right (it's what I did anyway). Which submission are you referring to?

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

Problem E Flushing Problem what's the wrong with using '\n' always (Idleness limit exceeded on test 1), using endl (Accepted)

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I submited with '\n' and it passed.

  • »
    »
    45 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it
    • ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
    • cout<<"! "<<s<<'\n';
    • fflush(stdout);

    No! First one unties cin/cout operations from stdin/stdout operations, so it is implementation-defined (or even undefined, but no sure) behaviour to mix up them both after that.

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

prefixforce

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

The problem F was not hard to understand but hard to implement. My guess is that there is probably a great implementation that does not require bunch of if and else blocks.

Can someone share a nice and compact implementation or the idea behind it?

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

F with simulation

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

How on earth Yodasen made possible to write solution and submit within the time interval of 5 second (solution A(3 min 53s) & D(3 min 48s)) and 21 second (solution C(7 min 30s) & G1(7 min 9s)) second!

Is this real??

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

How to solve F?

  • »
    »
    37 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Simulate the process of bouncing the ball but only care about the border cells that the ball will touch. In order to avoid infinite loop you have to use a MAP or similar data structures to record you path (this includes the direction as well).

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

Need to focus on my implementation writing this so that after a month when I look back at my stupid doubt and comment I could have a laugh btw Gennady aka tourist look out I am coming after you(IK i sound stupid). Totally got stuck on E even after knowing how to solve it i wasn't able to implement it.

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

for problem E i came up with approach and coded it out but it wasn't working can anyone please have a look at my code and tell me where I was going wrong. Submission Link:- https://codeforces.com/contest/1807/submission/198251608

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

problem G2 should be c or something! , really? G2 is a simple greedy problem?

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

The contest was really interesting, thank you forbthis awesome problems, but the slow judgement and delaying the contest twice were soooo annoying. Good luck and thank you again!

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

Please, can someone explain why i'm getting "Idleness limit exceeded on test 1"? Here's my solution: 198278358

  • »
    »
    2 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I also did the same mistake. your output for the system was "?" mid, but here you should ask for mid-l+1 because of this the system is waiting for more queries. (sorry for bad english not my native)

    • »
      »
      »
      2 days ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      That makes sense. I think i've noticed this in other part of solution, but somehow forgot about it. I've get accepted, thank you!

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

Nice Questions

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

For problem F, while contest I didn't read constraints properly, I designed more generalised solution. my solution will work for N <= 10^5 ( or even N <= 10^6 ) .

[submission:https://codeforces.com/contest/1807/submission/198280396] .

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

    I don't think you solution is a more generalized version. If the pigeonhole thingy from your solution actually holds, then it holds in everyone's solution that memoized too.

    • »
      »
      »
      47 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      most of the solutions are using dx[4] = {1,1,-1,-1}, dy[4] = {1,-1,1,-1} , and ball is moving one by one step( from cell (i,j) to (i+1,j+1) or (i-1,j-1) .. etc ).

      In my solution, ball jumping from one wall to another wall in O(1) time.

      Pigeonhole principle will hold only for boundary cells. Not for inner cells.

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

Hello, why is my code for problem D giving WA on test case 4? The logic should be correct and I cannot think of any bugs. Is there something I have failed to account for? There shouldn't be any issues with int overflow I believe.

Code

Thank you all very much in advance.

  • »
    »
    47 hours ago, # ^ |
    Rev. 2   Vote: I like it +8 Vote: I do not like it
    1
    3 1
    1 1 1
    1 3 999999999
    

    Your code outputs "NO" instead of "YES"

    The error is that l, r, and k are ints, so temp += (r-l+1)*k first evaluates (r-l+1)*k as an int, which overflows.

    • »
      »
      »
      47 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Thank you very much for the help, it worked. Unfortunate that I missed that in contest.

  • »
    »
    41 hour(s) ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I think (r-l+1)*k can overflow

»
46 hours ago, # |
  Vote: I like it 0 Vote: I do not like it

how is e related to dp???

  • »
    »
    42 hours ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    if you sort array, then:
    dp[i][s] = if you can make sum S using the first i elements

    base case:
    dp[1][1] = 1 (and check if a[1] == 1)

    transition is:
    dp[i+1][s] = dp[i][s] | dp[i][s-a[i]]

    Observation is that if some sum t can be created using first p elements, then it's also possible to create any sum <= t. So we can remove one dimension from the dp and store only the max s for which dp[i][s] = true.

    This is actually how my reasoning went during the contest.

    • »
      »
      »
      39 hours ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Can you prove this observation?

      • »
        »
        »
        »
        36 hours ago, # ^ |
        Rev. 2   Vote: I like it +5 Vote: I do not like it

        proof by induction:

        Define s[i] max sum that can be created from first i elements.

        It's true for i == 1, because a[1] == 1 and it's possible to create sum s[1] = 1 only

        Assume it's true for i, now prove that it's also true for i+1. If a[i+1] is greater than s[i], then the answer is NO, so assume a[i+1] <= s[i]. There are 2 cases. To create sum x <= s[i] we can do so without including current element, because it's already possible to do so using previous elements. To create s[i] < x <= s[i] + a[i+1] we can use current element, and create sum x - a[i+1