http://codeforces.net/contest/512/problem/B
solution id : 12300691 and 12300696 http://codeforces.net/submissions/arbit
unordered_map is giving wrong answers while map gives the correct answer.
# | 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 |
http://codeforces.net/contest/512/problem/B
solution id : 12300691 and 12300696 http://codeforces.net/submissions/arbit
unordered_map is giving wrong answers while map gives the correct answer.
Name |
---|
Looks like you use fact, that in map all pairs are sorted. It's true for normal map(because it's based on BST), but wrong for unordered_map(because it's based on hash table and keys are sorted not by value, but by hashs)
According to the solution, the ordered property is not making any difference.
Ok, that's my error :(
Here
You can add element to map. Maybe it can make iterator it1 invalid...
According to what you are saying, map should give wrong answers however it is the other way round.
When you change container there are magic with iterators, so it's better just not to do it :) You can never be sure what you will get
std::map
andstd::unordered_map
have different iterator invalidation rules. Basically, anystd::unordered_map
iterator can be invalidated after any insertion or deletion because of rehashing, and you can't control it. On other hand,std::map
iterator is guaranteed to be valid until you erase it explicitly. That's why you got 2 different results.