2022-2-6动态规划day10

题1:

有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,以价格 pricei 抵达 toi

现在给定所有的城市和航班,以及出发城市 src 和目的地 dst,你的任务是找到出一条最多经过 k 站中转的路线,使得从 src 到 dst 的 价格最便宜 ,并返回该价格。 如果不存在这样的路线,则输出 -1

 

示例 1:

输入: 
n = 3, edges = [[0,1,100],[1,2,100],[0,2,500]]
src = 0, dst = 2, k = 1
输出: 200
解释: 
城市航班图如下
从城市 0 到城市 2 在 1 站中转以内的最便宜价格是 200,如图中红色所示。

示例 2:

输入: 
n = 3, edges = [[0,1,100],[1,2,100],[0,2,500]]
src = 0, dst = 2, k = 0
输出: 500
解释: 
城市航班图如下
从城市 0 到城市 2 在 0 站中转以内的最便宜价格是 500,如图中蓝色所示。

 

提示:

  • 1 <= n <= 100
  • 0 <= flights.length <= (n * (n - 1) / 2)
  • flights[i].length == 3
  • 0 <= fromi, toi < n
  • fromi != toi
  • 1 <= pricei <= 104
  • 航班没有重复,且不存在自环
  • 0 <= src, dst, k < n
  • src != dst
复制代码
 1 class Solution {
 2     public int findCheapestPrice(int n, int[][] flights, int src, int dst, int k) {
 3         int[][] dp=new int[k+2][n];
 4         //dp[i][j]表示经过i次中转 起点到达j的最小值
 5         for (int i=0;i<=k+1;i++) Arrays.fill(dp[i],Integer.MAX_VALUE/2);
 6         //初始化都为无穷大
 7         dp[0][src]=0;
 8         //不中转到达起点的距离为0
 9         // 一共最多中转K次,但是中转0次也要计算
10         for (int i=1;i<k+2;i++) {
11             // 遍历所有边,松弛
12             for (int[] x:flights) {
13                 int from=x[0],to=x[1],cost=x[2];
14                 // dp[i][to] 第i次到达to地点,可以用这条边松弛 第i-1次到达from+边的权重
15                 dp[i][to]=Math.min(dp[i][to],dp[i-1][from]+cost);
16             }
17         }
18         int ans=Integer.MAX_VALUE/2;
19         for (int i=1;i<k+2;i++) ans=Math.min(ans,dp[i][dst]);
20         return ans==Integer.MAX_VALUE/2?-1:ans;
21     }
22 }
复制代码

思路:动态规划,具体见注释。

posted on   阿ming  阅读(27)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示