给定一棵有n个结点的有根树,结点依次以1,2,…….,n编号其中根结点的编号为1。
小A计划在这棵有根树上进行q次旅行。在第i次旅行中,小A首先会选定结点s作为起点,并移动若干次。移动分为以下两种:
1.移动至当前结点的父结点。特殊地,如果当前位于根结点,则不进行移动。
2.移动至当前结点的所有子结点中编号最小的结点。特殊地,如果当前位于叶子结点,则不进行移动。
由于移动次数可能很大,对于第i次旅行,旅行中的移动将以 ki 个不为零的整数构成的序列 ai1,ai2,…,ai,ki表示。对于ai,j,若 ai,j>0则代表进行ai,j次第一种移动;若 ai,j<0则代表进行-ai,j次第二种移动。根据给出的序列从左至右完成所有移动后,小A所在的结点即是旅行的终点。
给定每次旅行的起点与移动序列,请你求出旅行终点的结点编号。
第⼀⾏,两个正整数n,q,分别表⽰有根树的结点数量,以及旅⾏次数。 第⼆⾏,n-1个整数p2,p3,……,pn,其中pi表⽰结点i的⽗结点编号。
接下来2q行中的第2i-1行(1≤i≤q)包含两个正整数 si,ki,分别表示第i次旅行的起点编号,以及移动序列的长度。第 2i 行包含k个整数ai,1,ai,2,·.·,ai,k,表示移动序列。
输出共q行,第i行包含一个整数,表示第i次旅行终点的结点编号。
5 4 1 1 2 2 3 3 1 -1 -1 2 5 1 -1 1 -1 1 5 8 1 1 1 -1 -1 -1 -1 -1 5 3-1 -1 1
4 1 4 2
8 3 5 4 2 1 3 6 6 8 1 8 8 2 8 -8 8 3 8 -8 8
1 7 1
| 子任务编号 | 测试点占比 | n | q | ∑ki | 特殊性质 |
|---|---|---|---|---|---|
| 1 | 20% | ≤100 | ≤100 | ≤1000 | 保证 ai,j 为 1 或 −1 |
| 2 | 20% | ≤104 | ≤104 | ≤4×104 | 仅包含第一种移动 |
| 3 | 20% | ≤104 | ≤104 | ≤4×104 | 仅包含第二种移动 |
| 4 | 40% | ≤105 | ≤2×104 | ≤105 | - |
对于所有测试点,保证: