I had a weird WA during Round #300 (B) for the test case 415
. I used the custom invocation tool and realized that ((int) pow(10, i))
when i=2
is equal to 99 and the number
becomes 100
instead of 101
. On my machine, the same code passed.
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3885 |
3 | jqdai0815 | 3682 |
4 | Benq | 3580 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3506 |
7 | ecnerwala | 3505 |
8 | Radewoosh | 3457 |
9 | Kevin114514 | 3377 |
10 | gamegame | 3374 |
# | User | Contrib. |
---|---|---|
1 | cry | 170 |
2 | -is-this-fft- | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
8 | awoo | 152 |
10 | maomao90 | 148 |
I had a weird WA during Round #300 (B) for the test case 415
. I used the custom invocation tool and realized that ((int) pow(10, i))
when i=2
is equal to 99 and the number
becomes 100
instead of 101
. On my machine, the same code passed.
Name |
---|
Never use floating point functions. If you still want to use it, make sure you round instead of cast.
I see. I should probably avoid those. Thanks!
pow works in doubles. Answer can differ because of different compilers. In this case pow(10, 2) = 99.99999..., and it casts to 99. To avoid such bugs you can add eps to result, and cast it to int only after that.
P.S. your code get AC using MS compiler: 10898670
Thank you for the explanation!
you could use power, see this AC solution 10899961
I explained it here.
Interesting. Thanks!