luogu#P10302. [THUWC 2020] 某科学的动态仙人掌

[THUWC 2020] 某科学的动态仙人掌

题目描述

题目名是吸引你点进来的。

给一棵边权为 11 的树和一个常数 XX,节点用 11nn 的整数表示。

定义 dist(a,b)dist(a,b) 为节点 a,ba,b 在树上的距离,即 aabb 的简单路径上的边权和,特别地,dist(a,a)=0dist(a,a) = 0

每次查询的时候给出一个区间 [l,r][l,r],查询有多少个 XX-块,定义如下:

对任意两个节点 a,ba,b,定义 a,ba,bXX-连通的,当且仅当存在一个长为 tt 的节点序列 {vi}\{v_i\},其中 tt 可以是任意正整数,满足:

  1. v1=av_1=a
  2. vt=bv_t=b
  3. 对任意 1it11\le i\le t-1dist(vi,vi+1)Xdist(v_i,v_{i+1})\le X
  4. 对任意 1it1\le i\le tlvirl\le v_i\le r

定义“XX-块”为一个点集 SS,满足:

  1. 对任意 aa 属于 SSbb 属于 SS 的补集且 lbrl\le b \le ra,ba,b 不是 X-连通的;
  2. 对任意 a,ba,b 属于 SSaabb 是 X-连通的;
  3. 对任意 aa 属于 SS,有 larl\le a \le r

输入格式

第一行三个整数 nnmmXX 依次表示树的节点个数,询问次数,还有常数 XX

第二行共 n1n-1 个整数 p2  p3    pnp_2\;p_3\;\dots\;p_n,表示对于 2in2 \le i\le n 的整数 iiiipip_i 之间有一条无向边;

保证输入的数据构成一棵树;

之后 mm 行,每行两个整数 l    rl\;\;r,表示这次询问的区间是 [l,r][l,r],保证 lrl \le r

保证 1n31051 \le n\le 3\cdot 10^51m61051 \le m\le 6\cdot 10^5

输出格式

mm 行,依次回答各组询问:每行输出一行一个整数表示这组询问的答案。

10 9 2
1 1 1 2 3 4 1 1 1
1 3
2 4
3 5
4 6
5 7
6 8
7 9
8 10
5 5

1
1
2
3
3
3
2
1
1

提示

本题有多个子任务,每个子任务可能包含多个测试点,只有通过了一个子任务中的所有测试点才能得到该子任务的分数。

每个子任务的测试点满足一些特殊的限制,具体如下表:

子任务 分数 nn mm XX 性质 1 性质 2
11 44 100100 1010
22 3×1053\times 10 ^ 5 6×1056\times 10 ^ 5 299999299999
33 1616 299900299900
44 11
55 88 22
66 33
77 44
88 1×1051\times 10 ^ 5 3×105\le 3\times 10 ^ 5
99 44 3×1053\times 10 ^ 5 6×1056\times 10 ^ 5
1010 88 3×1053\times 10 ^ 5
1111 44
1212 88 1×1051\times 10 ^ 5 2×1052\times 10 ^ 5
1313 2×1052\times 10 ^ 5 4×1054\times 10 ^ 5
1414 3×1053\times 10 ^ 5 6×1056\times 10 ^ 5

其中,性质 1、性质 2 的含义如下:

性质 1:存在一个点 ww 使得 dist(1,w)=n1dist(1,w)=n-1

性质 2:n=mn=m,且第 ii 次询问为 l=1,  r=il=1,\;r=i