fatemetmhr's blog

By fatemetmhr, history, 21 month(s) ago, In English

Hi! Well I'm again facing this problem with resubmissions! As I said here, cf's mirrors may not recognize double submissions of a same code. Today, cf was checking my connection security every single time I wanted to load a page during the contest. When I wanted to submit for problme C, the checking process was taking to much time, so I stoped it, checked my submissions in m3.codeforces... there wasn't anything, then I submitted the same code and after a while I saw another submission for C. Codes are again exactly the same, no extra space or newline ... MikeMirzayanov please check it, please fix this issue, and please remove my second submission.

Full text and comments »

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

By fatemetmhr, history, 2 years ago, In English

Hi! Today, at the begining of round #845, I faced some problems with CF. Don't know if it's all about my own connection or anything about CF's servers, but I wasn't aware from it and submitted my code for problem A, which resulted in a loading page. As I saw CF isn't loading, I resubmitted the same code with m1.codeforces (since I thought my previous submission wouldn't be sent at all). And I even stoped loading codeforces.com to avoid resubmission. But the code was already posted and I realized this too late.

Now I'm just thinking... shouldn't be some other rules about penalty of resubmissions? Maybe CF could just check all codes and don't count two submissions with a same code as a penalty? Or just allows any resubmission during downtime of the server?

Anyway, the round wasn't rated for me, and I'm advising these things for future rounds...

Full text and comments »

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

By fatemetmhr, 2 years ago, In English

Hi!

Yesterday I was solving problem 1743C - Save the Magazines, when I faced a strange verdict. My code was getting WA with C++20 (176908643), while everything was ok with C++17 (176909474, 176989803). I tried looking for anything in my code that may cause undefined behavior, nothing found. Also there were something more strange as well; Like these two:

  • Changing the order of two variables in line 43 caused different verdict (176965105).

  • Adding a single line of cerr << 1;, again,caused different verdict (176965552).

and many other strange behaviours...

Here's a smaller code which has different verdicts in GNU G++20 11.2.0 (64 bit, winlibs) and GNU G++17 7.3.0 on Codeforces's custom test. You can check it out yourself, but as far as I know there's nothing special or causing undefined behaviour in this code:

Code

UPD: Simpler code by pajenegod

UPD 2: Extremely simpler code by nor

UPD 3: I also reported the problem on Bugzilla (Link)

What's really happening ?

It's all about tree-loop-distribute-patterns flag. You can learn about it here. But there's a problem in GCC 11.2. While compiling a code like:

for (...) {
    a[i] = 0;
    b[i] = 0;
    if (...) a[i] = a[i-1] + 1;
}

it generates something like:

memset(a, 0, sizeof a);
for (...) {
    if (...) a[i] = a[i-1] + 1;
}
memset(b, 0, sizeof b);

And that's why the verdict differs just by changing the order of those two variables. As you can see here:

  • First there's a memset in line 85.

  • Then the for will run.

  • Finally in line 122 there's the last memset, which destroys everything!

It seems that this problem starts from GCC 10.1, so GNU G++17 7.3.0 and GNU G++17 9.2.0 work correctly.

The default optimizition used by Codeforces for both C++20 and C++17 is O2. The flag tree-loop-distribute-patterns works automatically in O2 and later. So the code with O1 optimization will run correctly. In O3 and later, another flag, tree-vectorize, has been included, which fixes this bug; So, again, if you use O3 or Ofast it will run correctly.

But there's still something strange. The code with O0 works ok (177008931), also the one with an extra flag tree-loop-distribute-patterns wroks ok as well! (177008871)

Anyway! It's a serious bug, but it seems that ‍O2 in GCC 12 has the flag tree-vectorize. So currently, with this version of GCC which is the only available version for C++20 here, it isn't safe to use C++20 on Codeforces without extra flags (at least for me!). I highly recommend using C++17 instead of C++20 if possible, or using some extra flags like tree-vectorize, I truly hope this one won't cause any other strange behaviour!

Thanks to Davoth, ymmparsa and specially AaParsa that almost everything I shared was with great help of them. I was just the poor one who faced the problem :')

Full text and comments »

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