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 <= 1000 <= flights.length <= (n * (n - 1) / 2)flights[i].length == 30 <= fromi, toi < nfromi != toi1 <= pricei <= 104- 航班没有重复,且不存在自环
0 <= src, dst, k < nsrc != 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 }
思路:动态规划,具体见注释。
浙公网安备 33010602011771号