Hello 2025 |
---|
Закончено |
Это сложная версия задачи. Отличие между версиями заключается в том, что в этой версии Дополнительные ограничения на $$$m$$$ отсутствуют. Вы можете делать взломы только в том случае, если решили все версии этой задачи.
Недавно преподавателям «Т-поколения» нужно было сделать учебный контест. Им не хватает одной задачи, и в контесте как раз нет ни одной задачи на графы, поэтому они придумали следующую задачу.
Вам дан связный взвешенный неориентированный граф из $$$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$$$.
Для каждого набора входных данных выведите ответы на все вопросы.
34 4 21 2 22 4 21 3 43 4 11 4 22 3 16 7 31 2 102 3 33 4 94 5 25 6 12 4 104 6 101 6 31 6 22 4 111 17 101 4 51 3 191 2 103 2 134 5 14 6 113 5 93 6 182 7 175 8 155 10 86 9 47 10 207 8 168 11 39 11 610 11 143 11 13 11 31 11 11 11 41 11 38 2 210 4 13 9 23 9 16 7 3
1 2 2 9 9 11 3 11 1 3 10 8 4 11 4
В первом наборе входных данных одним из оптимальных путей в первом запросе является путь $$$1 \rightarrow 3 \rightarrow 4$$$, $$$2$$$-й максимум весов ребер на этом пути это $$$1$$$. Во втором запросе одними из оптимальных путей являются путь $$$2 \rightarrow 4 \rightarrow 3$$$, $$$1$$$-й максимум весов ребер это $$$2$$$.
Во втором наборе входных данных одним из оптимальных путей в первом запросе является путь $$$1 \rightarrow 2 \rightarrow 4 \rightarrow 5 \rightarrow 6$$$, $$$3$$$-й максимум весов ребер на этом пути это $$$2$$$.
Название |
---|