mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
52 lines
2.8 KiB
HTML
52 lines
2.8 KiB
HTML
<p>有 <code>n</code> 个城市通过一些航班连接。给你一个数组 <code>flights</code> ,其中 <code>flights[i] = [from<sub>i</sub>, to<sub>i</sub>, price<sub>i</sub>]</code> ,表示该航班都从城市 <code>from<sub>i</sub></code> 开始,以价格 <code>price<sub>i</sub></code> 抵达 <code>to<sub>i</sub></code>。</p>
|
||
|
||
<p>现在给定所有的城市和航班,以及出发城市 <code>src</code> 和目的地 <code>dst</code>,你的任务是找到出一条最多经过 <code>k</code> 站中转的路线,使得从 <code>src</code> 到 <code>dst</code> 的 <strong>价格最便宜</strong> ,并返回该价格。 如果不存在这样的路线,则输出 <code>-1</code>。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
<img alt="" src="https://assets.leetcode.com/uploads/2022/03/18/cheapest-flights-within-k-stops-3drawio.png" style="width: 332px; height: 392px;" />
|
||
<pre>
|
||
<strong>输入:</strong>
|
||
n = 4, flights = [[0,1,100],[1,2,100],[2,0,100],[1,3,600],[2,3,200]], src = 0, dst = 3, k = 1
|
||
<strong>输出:</strong> 700
|
||
<strong>解释:</strong> 城市航班图如上
|
||
从城市 0 到城市 3 经过最多 1 站的最佳路径用红色标记,费用为 100 + 600 = 700。
|
||
请注意,通过城市 [0, 1, 2, 3] 的路径更便宜,但无效,因为它经过了 2 站。
|
||
</pre>
|
||
|
||
<p><strong>示例 2:</strong></p>
|
||
<img alt="" src="https://assets.leetcode.com/uploads/2022/03/18/cheapest-flights-within-k-stops-1drawio.png" style="width: 332px; height: 242px;" />
|
||
<pre>
|
||
<strong>输入:</strong>
|
||
n = 3, edges = [[0,1,100],[1,2,100],[0,2,500]], src = 0, dst = 2, k = 1
|
||
<strong>输出:</strong> 200
|
||
<strong>解释:</strong>
|
||
城市航班图如上
|
||
从城市 0 到城市 2 经过最多 1 站的最佳路径标记为红色,费用为 100 + 100 = 200。
|
||
</pre>
|
||
|
||
<p><strong class="example">示例 3:</strong></p>
|
||
<img alt="" src="https://assets.leetcode.com/uploads/2022/03/18/cheapest-flights-within-k-stops-2drawio.png" style="width: 332px; height: 242px;" />
|
||
<pre>
|
||
<b>输入:</b>n = 3, flights = [[0,1,100],[1,2,100],[0,2,500]], src = 0, dst = 2, k = 0
|
||
<b>输出:</b>500
|
||
<strong>解释:</strong>
|
||
城市航班图如上
|
||
从城市 0 到城市 2 不经过站点的最佳路径标记为红色,费用为 500。
|
||
</pre>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= n <= 100</code></li>
|
||
<li><code>0 <= flights.length <= (n * (n - 1) / 2)</code></li>
|
||
<li><code>flights[i].length == 3</code></li>
|
||
<li><code>0 <= from<sub>i</sub>, to<sub>i</sub> < n</code></li>
|
||
<li><code>from<sub>i</sub> != to<sub>i</sub></code></li>
|
||
<li><code>1 <= price<sub>i</sub> <= 10<sup>4</sup></code></li>
|
||
<li>航班没有重复,且不存在自环</li>
|
||
<li><code>0 <= src, dst, k < n</code></li>
|
||
<li><code>src != dst</code></li>
|
||
</ul>
|