#L3828. 「SDOI2012」集合

「SDOI2012」集合

题目描述

小 H 在学习「集合与图论」的时候遇到了一个问题,他思考了很久依然无法很好完成这个问题。于是他只好来求助你了。

给出 nn 个点 mm 条边的带权无向图(即每条无向边上都有一个权值),有 33 个集合 AABBCC。一开始无向图中所有点都属于 AA 集合,有如下 99 种操作:

  • MoveA x\text{MoveA } x:表示将第 xx 个点从所在集合中删除,并加入至 AA 集合。
  • MoveB x\text{MoveB } x:表示将第 xx 个点从所在集合中删除,并加入至 BB 集合。
  • MoveC x\text{MoveC } x:表示将第 xx 个点从所在集合中删除,并加入至 CC 集合。
  • AskAA\text{AskAA}:询问两个端点都属于 AA 集合的所有边中最小的权值是多少。
  • AskAB\text{AskAB}:询问两个端点分别属于 AA 集合和 BB 集合的所有边中最小的权值是多少。
  • AskAC\text{AskAC}:询问两个端点分别属于 AA 集合和 CC 集合的所有边中最小的权值是多少。
  • AskBB\text{AskBB}:询问两个端点都属于 BB 集合的所有边中最小的权值是多少。
  • AskBC\text{AskBC}:询问两个端点分别属于 BB 集合和 CC 集合的所有边中最小的权值是多少。
  • AskCC\text{AskCC}:询问两个端点都属于 CC 集合的所有边中最小的权值是多少。

你能帮助他解决这个问题吗?

输入格式

输入的第 11 行有两个正整数,分别表示 nnmm

在第 22 行至第 m+1m + 1 行中,每行有三个正整数,分别为 u,v,wu, v, w。表示这条无向边的两个端点分别为 uuvvuvu \neq v),且这个边的权值为 ww

m+2m + 2 行有一个正整数 qq ,表示有 qq 个询问。

m+3m + 3 行至第 m+q+2m + q + 2 行中,每行的输入方式为题目描述里 99 种操作中的一种。

输出格式

对于所有的 Ask\text{Ask} 操作输出最小的权值,如果不存在则输出 No Found!

样例

输入

4 3
1 2 1
2 3 2
3 1 3
5
AskAA
AskAB
MoveB 2
AskAA
AskAB

输出

1
No Found!
3
1

数据范围与提示

对于 100%100\% 的数据,n1×105n \leq 1 \times 10^5m5×105m \leq 5\times 10^5q1×105q \leq 1\times 10^5w109w \leq 10^9。且无向图上任意两个点之间至多能选出 33 条不相交的路径。