I recently solved the problem of Codeforces round 146.
This is the problem statement
C++17 submission: AC submission
C++14 submission: WA submission
Both the codes are exactly same but the verdict is different.
Can anyone explain why this happens?
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 167 |
2 | -is-this-fft- | 165 |
3 | Um_nik | 160 |
4 | atcoder_official | 159 |
5 | djm03178 | 158 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | awoo | 150 |
8 | luogu_official | 150 |
10 | TheScrasse | 146 |
I recently solved the problem of Codeforces round 146.
This is the problem statement
C++17 submission: AC submission
C++14 submission: WA submission
Both the codes are exactly same but the verdict is different.
Can anyone explain why this happens?
Name |
---|
Your code C++14 submission uses LCM(int, int) and passes 2 long long arguments. Integer overflow may cause the WA verdict.
Your C++17 submission uses std::LCM(long long, long long), a template instantiation of std::LCM, which is only available since C++17. The built-in LCM function accepts two long long arguments, which does not cause integer overflow.
UPD: AC submission.
Replacing
int lcm(int a, int b){return (a*b)/__gcd(a, b);}
with
ll lcm(ll a, ll b){return (a*b)/__gcd(a, b);}
fixes the problem in C++14.
In C++14 your code calls on your int based lcm, which causes UB.
Not only does it use int, it is also written in such that it can easily overflow. Switching it to
gives AC 81694498.
As for why C++17 survives. In C++17 they added lcm to the standard library, so your call to lcm actually calls std::lcm.