loj#P2032. 「SDOI2016」游戏

「SDOI2016」游戏

题目描述

Alice 和 Bob 在玩一个游戏。

游戏在一棵有 nn 个点的树上进行。最初,每个点上都只有一个数字,那个数字是 123456789123456789123456789123456789
有时,Alice 会选择一条从 sstt 的路径,在这条路径上的每一个点上都添加一个数字。对于路径上的一个点 rr,若 rrss 的距离是 dis\mathrm{dis},那么 Alice 在点 rr 上添加的数字是 adis+ba\cdot \mathrm{dis}+b。有时,Bob 会选择一条从 sstt 的路径。他需要先从这条路径上选择一个点,再从那个点上选择一个数字。

Bob 选择的数字越小越好,但大量的数字让 Bob 眼花缭乱。

Bob 需要你帮他找出他能够选择的最小的数字。

输入格式

第一行两个数字 n,mn,m,表示树的点数和进行的操作数。
接下来 n1n−1 行,每行三个数字 u,v,wu,v,w,表示树上有一条连接 u,vu,v 的边,长度是 ww
接下来 mm 行。每行第一个数字是 1122
若第一个数是 11,表示 Alice 进行操作,接下来四个数字 s,t,a,bs,t,a,b
若第一个数是 22,表示 Bob 进行操作,接下来两个数字 s,ts,t

输出格式

每当 Bob 进行操作,输出一行一个数,表示他能够选择的最小的数字。

3 5
1 2 10
2 3 20
2 1 3
1 2 3 5 6
2 2 3
1 2 3 -5 -6
2 2 3
123456789123456789
6
-106

数据范围与提示

测试点 1 ~ 2:1n101\le n \leq 10 1m101\le m \leq 10 a10000 \left| a \right| \leq 10000
测试点 3 ~ 4:1n10001\le n \leq 1000 1m10001\le m \leq 1000 a10000 \left| a \right| \leq 10000
测试点 5:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a=0 a = 0 ,树是一条链;
测试点 6 ~ 7:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a=0 a = 0
测试点 8:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a=1 a = 1 ,树是一条链;
测试点 9 ~ 10:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a=1 a = 1
测试点 11 ~ 13:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a10000 \left| a \right| \leq 10000 ,树是一条链;
测试点 14 ~ 20:1n1000001\le n \leq 100000 1m1000001\le m \leq 100000 a10000 \left| a \right| \leq 10000 1u,v,s,tn1\le u,v,s,t\le n1w1091\le w\le 10^9b109|b|\le 10^9