luogu#P5384. [Cnoi2019] 雪松果树

[Cnoi2019] 雪松果树

题目背景

幻想乡,冬。

一年一度,生长在高山上的雪松果树又结果了。

Cirno 不知从哪弄到了 1,2,391,2,3\cdots9 颗雪松果,然后很开心的吃掉了其中 66 颗,最后还剩最后 11 颗。

Cirn o因为以后吃不到雪松果而感到忧愁,于是决定种在美丽的雾之湖畔。

第一天,发芽。

第二天,雪松果树长成了一颗参天大树, 上面长满了雪松果。

Cirno 在雪松果成熟之前早有一些问题想知道,但现在她忙于收集雪松果,就把问题丢给了你。

题目描述

雪松果树是一个以 11 为根有着 NN 个节点的树。

除此之外, Cirno还有 QQ 个询问,每个询问是一个二元组 (u,k)(u,k) ,表示询问 uu 节点的 kk-cousin 有多少个。

我们定义:

节点 uu11-father 为 路径 (1,u)(1, u) (不含 u)上距 u 最近的节点

节点 uukk-father 为 节点 「uu(k1)(k-1)-father」 的 1-father

节点 uukk-son 为所有 kk-father 为 uu 的节点

节点 uukk-cousin 为 节点「 uukk-father」的 kk-son (不包含 uu 本身)

输入格式

第一行,两个整数 NN, QQ

第二行, N1N-1 个整数,第 ii 个表示 i+1i+1 号节点的 1-father

以下 QQ 行,每行一个二元组(u,k)(u,k)

输出格式

一行,QQ 个数,每一个表示一个询问的答案。若 u 不存在 k-father,输出 0。

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

提示

数据范围:

对于0%-10%的数据 N,Q100N,Q \le 100

对于10%-20%的数据 N100,Q106N \le 100,Q \le 10^6

对于 20%-30% 的数据 N105,Q100N \le 10^5,Q \le100

对于 30%-35% 的数据 N104,Q5000N \le 10^4,Q \le 5000

对于 35%-50% 的数据 N105,Q105N \le 10^5,Q \le 10^5

对于 50%-70% 的数据 保证树随机

对于 70%-100% 的数据 N,Q106N,Q \le 10^6

另外存在一组记 2020 分的 hack 数据。