Unable to understand where my submission is failing. It looks like a standard DSU question. WA on TC-14.
https://mirror.codeforces.com/contest/755/submission/80885849
# | User | Rating |
---|---|---|
1 | tourist | 3993 |
2 | jiangly | 3743 |
3 | orzdevinwang | 3707 |
4 | Radewoosh | 3627 |
5 | jqdai0815 | 3620 |
6 | Benq | 3564 |
7 | Kevin114514 | 3443 |
8 | ksun48 | 3434 |
9 | Rewinding | 3397 |
10 | Um_nik | 3396 |
# | User | Contrib. |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 156 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
10 | nor | 152 |
Unable to understand where my submission is failing. It looks like a standard DSU question. WA on TC-14.
https://mirror.codeforces.com/contest/755/submission/80885849
Name |
---|
You have a bug in the union function, you should set parents of p1, p2 instead of x1, x2.
Also, this standard DSU question can be solved by counting a number of different values in the input sequence :)
It doesn't work :(
https://mirror.codeforces.com/contest/755/submission/80904257
Did I rectify it correctly?
Yes, the issue was a bit more subtle.
You collect the answer by checking number of different values in parent array. However, because you use path compression algorithm, some of the values may not be up-to-date.
You can either call find on all the nodes to solve this issue (this will update the values of parents for all nodes), or change the way in which you calculate the answer.