comments | difficulty | edit_url | tags | |||||
---|---|---|---|---|---|---|---|---|
true |
中等 |
|
给你两个整数 n
和 threshold
,同时给你一个 n
个节点的 有向 带权图,节点编号为 0
到 n - 1
。这个图用 二维 整数数组 edges
表示,其中 edges[i] = [Ai, Bi, Wi]
表示节点 Ai
到节点 Bi
之间有一条边权为 Wi
的有向边。
你需要从这个图中删除一些边(也可能 不 删除任何边),使得这个图满足以下条件:
- 所有其他节点都可以到达节点 0 。
- 图中剩余边的 最大 边权值尽可能小。
- 每个节点都 至多 有
threshold
条出去的边。
请你返回删除必要的边后,最大 边权的 最小值 为多少。如果无法满足所有的条件,请你返回 -1 。
示例 1:
输入:n = 5, edges = [[1,0,1],[2,0,2],[3,0,1],[4,3,1],[2,1,1]], threshold = 2
输出:1
解释:
删除边 2 -> 0
。剩余边中的最大值为 1 。
示例 2:
输入:n = 5, edges = [[0,1,1],[0,2,2],[0,3,1],[0,4,1],[1,2,1],[1,4,1]], threshold = 1
输出:-1
解释:
无法从节点 2 到节点 0 。
示例 3:
输入:n = 5, edges = [[1,2,1],[1,3,3],[1,4,5],[2,3,2],[3,4,2],[4,0,1]], threshold = 1
输出:2
解释:
删除边 1 -> 3
和 1 -> 4
。剩余边中的最大值为 2 。
示例 4:
输入:n = 5, edges = [[1,2,1],[1,3,3],[1,4,5],[2,3,2],[4,0,1]], threshold = 1
输出:-1
提示:
2 <= n <= 105
1 <= threshold <= n - 1
1 <= edges.length <= min(105, n * (n - 1) / 2).
edges[i].length == 3
0 <= Ai, Bi < n
Ai != Bi
1 <= Wi <= 106
- 一对节点之间 可能 会有多条边,但它们的权值互不相同。