#L2032. 「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 需要你帮他找出他能够选择的最小的数字。


输入格式

第一行两个数字nnmm,表示树的点数和进行的操作数。
接下来n1n-1行,每行三个数字uuvvww,表示树上有一条连接uuvv的边,长度是ww
接下来mm行。每行第一个数字是1122
若第一个数是11,表示 Alice 进行操作,接下来四个数字ssttaabb
若第一个数是22,表示 Bob 进行操作,接下来两个数字sstt


输出格式

每当 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 ~ 21n101 \le n \leq 101m101 \le m \leq 10a10000|a| \leq 10000
  • 测试点 3 ~ 41n10001 \le n \leq 10001m10001 \le m \leq 1000a10000|a| \leq 10000
  • 测试点 51n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a=0a = 0,树是一条链;
  • 测试点 6 ~ 71n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a=0a = 0
  • 测试点 81n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a=1a = 1,树是一条链;
  • 测试点 9 ~ 101n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a=1a = 1
  • 测试点 11 ~ 131n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a10000|a| \leq 10000,树是一条链;
  • 测试点 14 ~ 201n1000001 \le n \leq 1000001m1000001 \le m \leq 100000a10000|a| \leq 100001u,v,s,tn1 \le u,v,s,t \le n1w1091 \le w \le 10^9b109|b| \le 10^9