A90626.Another Exercise on Graphs
普及+/提高
通过率:0%
时间限制:1.00s
内存限制:512MB
题目描述
最近,"T-generation" 的导师需要筹备一场训练赛。他们发现缺少一道题目,且整场比赛中没有图论相关的问题,于是设计了如下题目。
给定一个包含 n 个顶点和 m 条边的连通带权无向图,图中无自环和重边。
处理 q 次形如 (a,b,k) 的查询:在从顶点 a 到顶点 b 的所有路径中,找出路径上边权的第 k 大值的最小值†。
导师们认为这个问题非常有趣,但存在一个问题:他们不知道如何解决它。请帮助他们解决这个问题,因为距离比赛开始仅剩几小时。
† 设 w1≥w2≥…≥wh 为某条路径中所有边权按非递增顺序排列后的结果。该路径边权的第 k 大值即为 wk。
输入格式
输入包含多组测试数据。第一行是一个整数 $ t ( 1 \le t \le 100 $),表示测试数据的组数。接下来是每组测试数据的详细描述。
每组测试数据的第一行包含三个整数 $ n, m $ 和 $ q ( 2 \le n \le 400 , n - 1 \le m \le \frac{n \cdot (n - 1)}{2} , 1 \le q \le 3 \cdot 10^5 $),分别表示图的顶点数、边数和查询数。
接下来的 $ m $ 行中,每行包含三个整数 $ v, u $ 和 $ w ( 1 \le v, u \le n , 1 \le w \le 10^9 $),表示图中的一条边及其权重。确保图中没有自环和重边。
接下来的 $ q $ 行中,每行包含三个整数 $ a, b $ 和 $ k ( 1 \le a, b \le n , k \ge 1 $),代表一个查询。确保从顶点 $ a $ 到顶点 $ b $ 的所有路径至少有 $ k $ 条边。
确保所有测试数据的 $ n $ 总和不超过 $ 400 $。
确保所有测试数据的 $ q $ 总和不超过 $ 3 \cdot 10^5 $。
输出格式
对于每组测试数据,输出所有查询的答案。
输入输出样例
输入#1
3 4 4 2 1 2 2 2 4 2 1 3 4 3 4 1 1 4 2 2 3 1 6 7 3 1 2 10 2 3 3 3 4 9 4 5 2 5 6 1 2 4 10 4 6 10 1 6 3 1 6 2 2 4 1 11 17 10 1 4 5 1 3 19 1 2 10 3 2 13 4 5 1 4 6 11 3 5 9 3 6 18 2 7 17 5 8 15 5 10 8 6 9 4 7 10 20 7 8 16 8 11 3 9 11 6 10 11 14 3 11 1 3 11 3 1 11 1 1 11 4 1 11 3 8 2 2 10 4 1 3 9 2 3 9 1 6 7 3
输出#1
1 2 2 9 9 11 3 11 1 3 10 8 4 11 4
说明/提示
样例说明
在第一组测试数据中,第一个查询的一个最优路径为 $ 1 \rightarrow 3 \rightarrow 4 $,这条路径上第二大的边权值为 $ 1 $。在第二个查询中,一个最优路径为 $ 2 \rightarrow 4 \rightarrow 3 $,该路径上最大的边权值为 $ 2 $。
在第二组测试数据中,第一个查询的一个最优路径为 $ 1 \rightarrow 2 \rightarrow 4 \rightarrow 5 \rightarrow 6 $,这条路径上第三大的边权值为 $ 2 $。