CF2122B.Pile Shuffling

传统题 时间 2000 ms 内存 256 MiB 5 尝试 1 已通过 1 标签

Pile Shuffling

题目描述

给定 nn 个二进制堆,其中第 ii 个堆顶部有 aia_i00,底部有 bib_i11

每次操作中,你可以取出任意堆的顶部元素,并将其移动到任意堆的任意位置(包括原堆)。

第一个测试样例的解法图示

上图为第一个测试样例的解法图示。

计算最少需要多少次操作,才能使第 ii 个堆形成顶部 cic_i00 和底部 did_i11 的目标状态。

输入格式

每个测试包含多个测试用例。第一行给出测试用例数量 tt1t1041 \le t \le 10^4)。随后是各测试用例描述。

每个测试用例第一行包含一个整数 nn1n21051 \leq n \leq 2 \cdot 10^5),表示堆的数量。

接下来 nn 行,第 ii 行包含四个整数 aia_i, bib_i, cic_i, did_i0ai,bi,ci,di1090 \leq a_i, b_i, c_i, d_i \leq 10^9),分别表示第 ii 个堆的初始状态和目标状态。

题目保证存在操作序列可以将所有堆转换为目标状态。

保证所有测试用例的 nn 总和不超过21052 \cdot 10^5

输出格式

对于每个测试用例,输出一个整数,表示达成目标状态所需的最少操作次数。

说明/提示

第一个测试用例的解法已在题面中展示。

第二个测试用例的最优解法如下:

第二个测试用例的最优解法

第三个测试用例中,所有堆已处于目标状态。

样例

3
2
1 3 1 2
1 1 1 2
3
2 0 2 2
0 1 1 0
1 1 0 0
3
1 2 1 2
3 4 3 4
0 0 0 0
2
3
0

在线编程 IDE

建议全屏模式获得最佳体验