P5384 [Cnoi2019] 雪松果树
题目背景
幻想乡,冬。
一年一度,生长在高山上的雪松果树又结果了。
Cirno 不知从哪弄到了 $1,2,3\cdots9$ 颗雪松果,然后很开心的吃掉了其中 $6$ 颗,最后还剩最后 $1$ 颗。
Cirno 因为以后吃不到雪松果而感到忧愁,于是决定种在美丽的雾之湖畔。
第一天,发芽。
第二天,雪松果树长成了一颗参天大树,上面长满了雪松果。
Cirno 在雪松果成熟之前早有一些问题想知道,但现在她忙于收集雪松果,就把问题丢给了你。
题目描述
雪松果树是一个以 $1$ 为根有着 $N$ 个节点的树。
除此之外,Cirno 还有 $Q$ 个询问,每个询问是一个二元组 $(u,k)$,表示询问 $u$ 节点的 $k$-cousin 有多少个。
我们定义:
> 节点 $u$ 的 $1$-father 为 路径 $(1, u)$ (不含 u)上距 u 最近的节点
>
> 节点 $u$ 的 $k$-father 为 节点 「$u$ 的 $(k-1)$-father」 的 1-father
>
> 节点 $u$ 的 $k$-son 为所有 $k$-father 为 $u$ 的节点
>
> 节点 $u$ 的 $k$-cousin 为 节点「 $u$ 的 $k$-father」的 $k$-son (不包含 $u$ 本身)
输入格式
第一行,两个整数 $N$, $Q$
第二行,$N-1$ 个整数,第 $i$ 个表示 $i+1$ 号节点的 1-father
以下 $Q$ 行,每行一个二元组$(u,k)$
输出格式
一行,$Q$ 个数,每一个表示一个询问的答案。若 u 不存在 k-father,输出 0。
说明/提示
数据范围:
|数据点编号|$N\le$|$Q\le$|特殊性质|
|----|----|----|-----|
|1,2|$100$|$100$||
|3,4|$100$|$10^6$||
|5,6|$10^5$|$100$||
|7|$10^4$|$5000$||
|8,9,10|$10^5$|$10^5$||
|11,12,13,14|$10^6$|$10^6$|**树随机生成**|
|15,16,17,18,19,20|$10^6$|$10^6$||
另外存在一组记 $20$ 分的 hack 数据。