https://atcoder.jp/contests/wtf22-day1/tasks/wtf22_day1_b?lang=en
置换环是用值连位
首先肯定要分成每个置换环,每个置换环操作次数只能是 s i z e − 1 size-1 size−1(置换环性质)
我们考虑置换环任意一次操作,会划分成两个小置换环,且他们都是连续段

考虑把环拉成一条链,两个位置交换就会划分成两个子区间(头尾再重新连在一起)
为了使结果合法(这里只的是能还原成排列),我们只能在这个子区间递归下去。
我们考虑这种情况,能够巧妙利用题目=的性质。

我们可以在左右跳来跳去
考虑回之前区间的限制,似乎建笛卡尔树能很好利用这堆性质
建好之后向上必然是更小,向下必然更大。我们进行中序遍历必然可以
本文讨论了在解题过程中如何处理置换环问题,强调每次操作会划分出大小为size-1的子环,通过递归分析和利用题目特性,指出构建笛卡尔树有助于管理和利用这些限制。

被折叠的 条评论
为什么被折叠?



