#P5168. xtq玩魔塔

xtq玩魔塔

题目背景

已添加样例解释

在小学五年级的时候,xtqxtq迷上了各种奇奇怪怪的魔塔。 关于魔塔游戏的背景:https://baike.baidu.com/item/魔塔/861619?fr=aladdin

对于题意理解可能并没有任何微小的作用

题目描述

xtq 现在正在玩一个魔塔。这个魔塔十分特殊,不是由正方形格子构成的,而是一个 nn 个点,mm 条边的无向图,而且每条边上都会有一个怪物。xtq 经过了重重阻拦,现在到达了一个奖励层。

在这层内,所有怪物都不会让 xtq 掉血,但是对于每一个怪物如果 xtq 不到一定血量他就无法攻击这个怪物。每一个点上还有一个宝石,宝石的种类有很多,但是如果 xtq 到了一个点但是他已经拥有了这种宝石,他是不能捡起的。他现在想要知道从这个魔塔的一个点到另一个点所需要的最小血量是多少,还要知道如果他从一个点到达这个魔塔,以某个血量能够捡到的宝石数量是多少。还有一件事令 xtq 十分头疼:这个魔塔由于一些神秘的力量,可能宝石的种类会发生变化。保证如果 xtq 的血量无穷大,他就可以走到这一层的任何地方。

输入格式

第一行三个数 n,m,qn,m,q 代表点数,边数和操作数量

第二行 nn 个数,代表每个点上宝石的种类

下面 mm 行每行三个数 u,v,tu,v,t,代表 uuvv 之间有一条路,路上有一个需要 tt 点血量才能击杀的怪物

然后 qq 行每行三个数 opt,x,yopt,x,y

opt=1opt=1 时将 xx 点的宝石改成第 yy

opt=2opt=2 代表查询从 xx 点要到达 yy 点所需的最小血量

opt=3opt=3 代表查询从 xx 点到达魔塔,血量为 yy 能捡到多少宝石

输出格式

对于每一个 22 操作和 33 操作,输出一行答案

4 4 4
4 6 4 2
1 2 8
3 2 3
2 4 2
4 1 7
3 4 3
1 4 4
3 1 7
2 4 3
3
2
3

提示

样例解释:

第一次操作为3号操作,从4开始,有3点血量,可以到达 {2,3,4}\{2,3,4\},可以获得的宝石种类为 {2,4,6}\{2,4,6\}

第二次将 11 的宝石种类修改为 44,即下图:

第三次为 33 操作,从 11 开始,可以到达的点为 {1,2,3,4}\{1,2,3,4\},可以获得的宝石种类为 {4,6}\{4,6\}

第四次为 22 操作,从 44 走到 33,至少需要 33 点血量。

测试点 nn mm qq 有无修改操作
11 1010 2020 1010
232 \sim 3 10001000 50005000 ^
454 \sim 5 80008000 3000030000 2000020000
66 2000020000 100000100000
77 ^
88 5000050000 200000200000
99 ^ ^
1010 100000100000 300000300000 ^

对于 100%100\% 的数据,n100000,m300000,q200000n \le 100000,m \le 300000,q \le 200000

剩余所有数字 intmax\le \text{intmax}

保证查询的区间是随机生成的(其实是出题人懒得再写 generator 了)