#CF2044G2. Medium Demon Problem (hard version)
Medium Demon Problem (hard version)
题目描述
这是该问题的困难版本。两个版本之间的关键区别已用粗体强调。
有一群 只蜘蛛聚在一起交换毛绒玩具。一开始,每只蜘蛛手里都有一个毛绒玩具。每年,如果第 只蜘蛛至少有一个毛绒玩具,它会把自己的一个毛绒玩具送给第 只蜘蛛。否则,它会选择不做任何事情。注意,所有毛绒玩具的转移同时进行。在这个版本中,每只蜘蛛在任何时候都可以拥有多个毛绒玩具。
如果今年(在进行交换之前)每只蜘蛛拥有的毛绒玩具数量与去年(交换之前)相同,那么这一年就是稳定的。需要注意的是,第一年不可能是稳定的。
请找出施行直到稳定的第一个年份。
输入格式
第一行输入一个整数 (),表示测试用例的数量。
每个测试用例的第一行包含一个整数 (),表示蜘蛛的数量。
接下来的一行包含 个整数 (),表示每只蜘蛛所指定的收件蜘蛛编号。
保证所有测试用例中 的总和不超过 。
输出格式
对于每个测试用例,输出一个整数代表过程第一次变得稳定的年份。
样例
5
2
2 1
5
2 3 4 5 1
5
2 1 4 2 3
5
4 1 1 5 4
10
4 3 9 1 6 7 9 10 10 3
2
2
5
5
5
样例说明
对于第二个测试用例:
- 第一年,每只蜘蛛拥有的毛绒玩具数量为:。接下来进行第一次交换。
- 第二年,每只蜘蛛拥有的毛绒玩具数量仍为:。由于这个数组与去年相同,所以第二年是稳定的。
对于第三个测试用例:
- 第一年,每只蜘蛛拥有的毛绒玩具数量为:。接下来进行第一次交换。
- 第二年,每只蜘蛛拥有的毛绒玩具数量变为:。随后进行第二次交换。
- 第三年,每只蜘蛛拥有的毛绒玩具数量变为:。随后进行第三次交换。
- 第四年,每只蜘蛛拥有的毛绒玩具数量变为:。随后进行第四次交换。
- 第五年,每只蜘蛛拥有的毛绒玩具数量仍为:。由于这个阵列与上一年相同,第五年是稳定的。
本翻译由 AI 自动生成
来源
Codeforces 2044G2,英文题名 Medium Demon Problem (hard version)。