题解
类似于线段树。维护当前比赛以及其前面的比赛的所有可能。以样例为例,初始状态为:
data:image/s3,"s3://crabby-images/3b9b7/3b9b7ed373876c721b04ee4e6c428316fdec51d2" alt=""
将5从?更新成1时,我们首先更新5的可能数。接着这个更新可能会影响到后续,因此第二步我们更新5的父亲。更新效果如下:
data:image/s3,"s3://crabby-images/cd604/cd604bdf4d9f7b7280630e2dadb2405d4ce64815" alt=""
将6更新成?时。我们还是先更新6,接着更新6的父亲,直到根:
data:image/s3,"s3://crabby-images/c1cda/c1cda542c6939b0146e604b2b63ca513ff4b806e" alt=""
将7更新成?时,同理:
data:image/s3,"s3://crabby-images/ecf22/ecf22051b50fe0ab4f098fd1579c840a14649d78" alt=""
于是每次操作最多更新沿途的k个节点。
代码
Java
Submission #118492114 - Codeforces
Codeforces. Programming competitions and contests, programming community
data:image/s3,"s3://crabby-images/59444/594442c2d6cfc27bb669576992a08b5182e367b0" alt=""
C++
Submission #118492337 - Codeforces
Codeforces. Programming competitions and contests, programming community
data:image/s3,"s3://crabby-images/102c3/102c3ec7680c61ddcb65a4062943110fcace4121" alt=""