CFCF2154D.Catshock

普及+/提高

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

有一只猫住在一棵有 nn 个节点的树上。猫一开始在节点 11,而你在节点 nn。你需要给猫写一封使用“跑酷”语言的留言,帮助它到达你所在的位置。

“跑酷”语言有两种指令:

  • 11 — 这意味着猫应该移动到它的任意一个相邻节点,如果有多个选择,它会随意选一个。如果没有相邻节点,它不会移动。
  • 2u2\,u — 这意味着摧毁节点 uu 以及与其相连的所有边。如果猫当前在节点 uu,它会死亡,所以应避免这种情况。如果节点 uu 已经被摧毁,则不会发生任何事情。

此外,不能有连续两条第二种指令。

可惜的是,“跑酷”语言是不明确的,因为猫每执行一次第一种指令可能会有多种选择。因此,你需要构造一个长度不超过 3n3n 的指令序列,使得无论猫如何选择,只要按照你的指令执行,最终它一定会到达节点 nn。可以证明,对于任意一棵树,这样的序列一定存在。

输入格式

每个测试点包含多组测试数据。第一行包含测试组数 tt1t1041 \le t \le 10^4)。接下来是每组测试数据的描述。

每组测试数据的第一行包含一个整数 nn2n21052 \le n \le 2 \cdot 10^5),表示树的节点数。

接下来 n1n-1 行,每行包含两个整数 uuvv1u,vn,uv1 \le u, v \le n, u \ne v),表示一对通过边连接的节点。保证所给的图是一棵树,没有自环,也没有重边。

所有测试组中 nn 的总和不超过 21052 \cdot 10^5

输出格式

对于每组测试数据,输出一个整数 kk0k3n0 \le k \le 3n),表示你要执行的操作次数。

接下来输出 kk 行,每行可以是以下两种格式之一:

  • 11 — 让猫移动到相邻节点(如果存在)。
  • 2u2\,u1un1 \le u \le n)— 删除节点 uu 及其所有相邻边。

输入输出样例

  • 输入#1

    4
    5
    1 2
    2 3
    1 5
    5 4
    2
    1 2
    4
    1 2
    1 3
    1 4
    6
    1 2
    1 3
    3 4
    4 5
    4 6

    输出#1

    2
    2 2
    1
    
    1
    1
    
    5
    2 2
    1
    1
    2 3
    1
    
    9
    2 2
    1
    2 1
    1
    2 3
    1
    1
    2 5
    1

说明/提示

各组测试数据输出之间有额外空行仅为展示清晰,选手无需输出空行。

下图展示了第一组测试数据中猫的路径:


可以看出,这里猫只有这一条路径,因此它一定会到达节点 55

对于第一组测试数据,以下这种指令序列是错误的:1\mathtt{1}, 2\mathtt{2}, 2\mathtt{2}。可能出现如下情况:


此时,猫死在了节点 22

首页