Can anyone explain why does the first code get Runtime Error?
Thanks!
# | 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 |
Can anyone explain why does the first code get Runtime Error?
Thanks!
Name |
---|
I tried debugging it and it seems to have something to do with the order of the equalization, and the vector usage. You cannot use [] operators when the size of vector is 0. So when we use in the first call reg[] we are trying to access an vector of size 0, which causes an error.
The problem ceases when we resize the vector to size 1. Here.
Or in your second example when we resize the vector using the function, before trying to access the vector itself.
Thank you for your reply!
But in this code I'm not using [] operator with an empty vector, and still have a runtime error?
The thing is: you use invalid memory when assigning to reg[x], because the function, which result is assigned to reg[x], does change the vector (and, possibly, it's allocation). See this comment for detailed explanation.
I suspect that function getRegIndex might cause vector relocation in memory, so reg[getRegIndex(1,reg)] won't be part of your vector anymore.
I think you are right, here I increase the capacity before calling the function and there is no problem.
Thank you!