CF2057E2 Another Exercise on Graphs (hard version)
题目描述
这是该问题的困难版本。不同版本间的区别在于此版本对 $m$ 有额外约束。只有在你解决了该问题的所有版本后,才能进行 hack。
最近,"T-generation" 的导师需要筹备一场训练赛。他们发现缺少一道题目,且整场比赛中没有图论相关的问题,于是设计了如下题目。
给定一个包含 $n$ 个顶点和 $m$ 条边的连通带权无向图,图中无自环和重边。
处理 $q$ 次形如 $(a, b, k)$ 的查询:在从顶点 $a$ 到顶点 $b$ 的所有路径中,找出路径上边权的第 $k$ 大值的最小值$^{\dagger}$。
导师们认为这个问题非常有趣,但存在一个问题:他们不知道如何解决它。请帮助他们解决这个问题,因为距离比赛开始仅剩几小时。
$^{\dagger}$ 设 $w_1 \ge w_2 \ge \ldots \ge w_{h}$ 为某条路径中所有边权按非递增顺序排列后的结果。该路径边权的第 $k$ 大值即为 $w_{k}$。
输入格式
输入包含多组测试数据。第一行是一个整数 $ 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 \rightarrow 3 \rightarrow 4 $,这条路径上第二大的边权值为 $ 1 $。在第二个查询中,一个最优路径为 $ 2 \rightarrow 4 \rightarrow 3 $,该路径上最大的边权值为 $ 2 $。
在第二组测试数据中,第一个查询的一个最优路径为 $ 1 \rightarrow 2 \rightarrow 4 \rightarrow 5 \rightarrow 6 $,这条路径上第三大的边权值为 $ 2 $。
**本翻译由 AI 自动生成**