Hello! :)
One of my friends(kia.masster) submitted a problem with these two codes:
The only difference is the "cerr" line. Why has this happened? :|
# | 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 | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Hello! :)
One of my friends(kia.masster) submitted a problem with these two codes:
The only difference is the "cerr" line. Why has this happened? :|
Name |
---|
Variable "s" was not initialized. This led to undefined behavior.
Hello! :)
1- It hasn't been initialized in second code also. 2- Where did you get this error? Be sure to compile it by GNU C++.
Hello there!
Yes, it wasn't initialized in both codes. But I said it led to undefined behavior, not 100% wrong answer. If s is automatically initialized by 0 by compilator then your solution passes. If it is initialized by something else — bad luck:(.
And I compiled this code by my Code:Blocks Gnu compiler. And the output was 0 on debug and 1 on release because of this problem.
s has a (pseudo) random value depending on the state of memory before using address X for variable s. The memory is not initialized at address X, so it still contains the value of the variable that was in that place before. So it depends on such strange things like calling printing routines. Printing routines use the memory, then mark it as free. But the memory is not usually cleared, it still contains the old values.
This regards to local variables. Global variables are initialized to 0.