题目描述
Alice 和 Bob 在玩一个游戏。
游戏在一棵有n个点的树上进行。最初,每个点上都只有一个数字,那个数字是123456789123456789。
有时,Alice 会选择一条从s到t的路径,在这条路径上的每一个点上都添加一个数字。对于路径上的一个点r,若r与s的距离是dis,那么 Alice 在点r上添加的数字是a⋅dis+b。有时,Bob 会选择一条从s到t的路径。他需要先从这条路径上选择一个点,再从那个点上选择一个数字。
Bob 选择的数字越小越好,但大量的数字让 Bob 眼花缭乱。
Bob 需要你帮他找出他能够选择的最小的数字。
输入格式
第一行两个数字n、m,表示树的点数和进行的操作数。
接下来n−1行,每行三个数字u、v、w,表示树上有一条连接u、v的边,长度是w。
接下来m行。每行第一个数字是1或2。
若第一个数是1,表示 Alice 进行操作,接下来四个数字s、t、a、b。
若第一个数是2,表示 Bob 进行操作,接下来两个数字s、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:1≤n≤10,1≤m≤10,∣a∣≤10000;
- 测试点 3 ~ 4:1≤n≤1000,1≤m≤1000,∣a∣≤10000;
- 测试点 5:1≤n≤100000,1≤m≤100000,a=0,树是一条链;
- 测试点 6 ~ 7:1≤n≤100000,1≤m≤100000,a=0;
- 测试点 8:1≤n≤100000,1≤m≤100000,a=1,树是一条链;
- 测试点 9 ~ 10:1≤n≤100000,1≤m≤100000,a=1;
- 测试点 11 ~ 13:1≤n≤100000,1≤m≤100000,∣a∣≤10000,树是一条链;
- 测试点 14 ~ 20:1≤n≤100000,1≤m≤100000,∣a∣≤10000,1≤u,v,s,t≤n,1≤w≤109,∣b∣≤109。