#P5669. [SDOI2018] 原题识别-改
[SDOI2018] 原题识别-改
题目背景
蒟蒻花了三天时间,研究出了这道题的线性空间,且不依赖输入的随机性的一种优(du)秀(liu)做法。于是她决定拿出来毒瘤一下大家。
题目描述
有一棵个点的有根树,根节点编号为,且编号为的节点有颜色。你需要支持次询问。询问有以下两种格式:
-
:询问树上编号为的节点到编号为的节点的最短路径中,不同的颜色有多少种。
-
:在节点到根节点的路径中随机选择一个点,在节点到根节点的路径中随机选择一个点,求询问 的答案期望。(路径包含, 和根节点)
对于询问,设答案为,到根节点的路径经过的点数为,到根节点的路径经过的点数为,你只需要输出。
输入格式
注意:输入格式与原题不同
每个测试点仅包含一组数据。
输入数据的第一行包含两个非负整数, ,表示节点个数和询问次数。
接下来一行包含个正整数,第个正整数为,表示节点的颜色。
接下来行,每行包含两个整数, ,表示编号为的节点和编号为的节点之间存在一条边。保证输入的边构成一棵树。
接下来行,每行包含一个询问。询问的格式和意义见题目描述。
输出格式
输出行,第行包含一个非负整数,表示第次询问的答案。
提示
对于所有数据,保证, 。保证输入的边构成一棵树。
子任务(分):保证不存在询问。
子任务(分):保证对于每一条边都有。
子任务(分):没有任何附加的限制。