# | User | Rating |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3773 |
3 | Radewoosh | 3646 |
4 | ecnerwala | 3624 |
5 | jqdai0815 | 3620 |
5 | Benq | 3620 |
7 | orzdevinwang | 3612 |
8 | Geothermal | 3569 |
8 | cnnfls_csy | 3569 |
10 | gyh20 | 3447 |
# | User | Contrib. |
---|---|---|
1 | cry | 161 |
2 | maomao90 | 160 |
3 | awoo | 159 |
4 | atcoder_official | 157 |
5 | -is-this-fft- | 155 |
5 | nor | 155 |
7 | adamant | 153 |
8 | maroonrk | 152 |
8 | Um_nik | 152 |
10 | djm03178 | 146 |
Name |
---|
Your solutions are really good.
Can someone pls explain D1? Shayan's solution is very elegant but I'm not able to grasp. Thnx alot in advance
Not exactly the same explanation in the video (as I didn't get it fully myself), but here is my understanding (might be wrong):
Idea: Keep track of which nodes of the tree have correctly placed children (think
bool[n]
). If in a permutation, all nodes have their children in the correct positions, then it is a valid DFS order.Note: We can ignore leaf nodes as they don't have children => "Always valid".
We start by checking which nodes have correctly placed children. I.e. For each non-leaf/parent node, we check that:
2**l
to the right. Wherel
is the level of the parent (0 being the bottom/leaf level).After each swap, we don't need to re-check the whole tree. We can just check, for each of the two swapped nodes (w/ some exceptions for root and leaf nodes) if:
After each swap, if at least one non-leaf node has a misplaced child, the answer is "NO", else, it's a "YES".
Ohh nice! Thanks for the explanation.
Also, I now understand what Shayan meant in the video. A text reference helps a lot. Thnx for taking out the time.
Why so many downvotes? He's doing great work. Taking out time, helping us understand & follow his thinking process & consistent streams for all rounds, with recent weekly topic streams as well. Such good contents & that too for free.
Upvoting and appreciation is the best that we can do! Pls don't downvote guys!
d2 sumbission link?