#P9776. [HUSTFC 2023] 狭义线段树
[HUSTFC 2023] 狭义线段树
题目描述
你打算建立一棵有 个节点,其中有 个叶子节点的二叉树。具体地,建立这棵树的伪代码如图所示。
不难发现,节点 是根节点,并且所有节点的编号与其 DFS 序相同。另外,你认为叶子节点十分重要,因此你按照节点编号从小到大又把这 个叶子节点分别称为 号叶子, 号叶子,, 号叶子。叶子节点会被其上方的节点管辖,具体来说,如果 号叶子在节点 的子树内,则称节点 管辖 号叶子,不妨用 表示;否则若节点 不管辖 号叶子,则 。注意,叶子节点同时也管辖自己本身。
同时,你认为一个好的二叉树要有点权,于是对于节点 ,定义其点权为 。初始所有节点的点权都为 。
在一次梦中,你正在改造这棵二叉树。你将会对这棵二叉树依次执行 次操作,每次操作的格式和描述如下:
- :对于所有的整数 ,将节点 的点权加 。
- :令 ,其中 表示节点 管辖的叶子节点的集合。然后对于 中所有叶子节点,将其点权加 。注意 是不重复集合,即在本次操作中,每个叶子节点最多被修改一次。
- :计算 ,其中 表示管辖 号叶子的所有节点的点权之和,即 。
你还想再加点操作,但是早八的铃声把你吵醒了,不过你还是决定实现一下这个奇思妙想。
输入格式
第一行包含一个整数 ,表示二叉树中叶子节点的数量。
第二行包含 个整数,其中第 个整数表示节点 的父亲节点编号。保证给出的树的形态与节点编号和题目所描述的相同。
第三行包含一个整数 ,表示操作次数。
接下来 行,每行第一个整数 表示操作类型,若 或 ,则紧跟三个整数 $s,t,v\ (1\le s\le t\le 2n-1,\ 0\le v<998\,244\,353)$,表示一次修改操作;若 ,则紧跟两个整数 ,表示一次询问操作。所有参数的含义如题目所述。
输出格式
对于每个 的操作,输出一行一个整数,表示本次询问的结果。
5
1 2 3 3 2 1 7 7
5
1 2 4 3
3 1 5
2 5 7 5
3 2 5
3 1 5
18
29
38