2022-04-28:有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,

Posted 福大大架构师每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2022-04-28:有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,相关的知识,希望对你有一定的参考价值。

2022-04-28:有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,以价格 pricei 抵达 toi。
现在给定所有的城市和航班,以及出发城市 src 和目的地 dst,你的任务是找到出一条最多经过 k 站中转的路线,使得从 src 到 dst 的 价格最便宜 ,并返回该价格。 如果不存在这样的路线,则输出 -1。
输入:
n = 3, edges = [[0,1,100],[1,2,100],[0,2,500]]
src = 0, dst = 2, k = 1
输出: 200
力扣787. K 站中转内最便宜的航班。

答案2022-04-28:

类似于宽度优先遍历。Bellman Ford算法,可以处理负边,但不能处理负数环。

代码用rust编写。代码如下:

fn main() 
    let n: isize = 3;
    let mut edges: Vec<Vec<isize>> = vec![vec![0, 1, 100], vec![1, 2, 100], vec![0, 2, 500]];
    let src: isize = 0;
    let dst: isize = 2;
    let k: isize = 1;
    let ans = find_cheapest_price2(n, &mut edges, src, dst, k);
    println!("ans = ", ans);


fn find_cheapest_price2(
    n: isize,
    flights: &mut Vec<Vec<isize>>,
    src: isize,
    dst: isize,
    k: isize,
) -> isize 
    let mut cost: Vec<isize> = vec![];
    for _k in 0..n 
        cost.push(9223372036854775807);
    
    cost[src as usize] = 0;
    for _i in 0..=k 
        let mut next: Vec<isize> = vec![];
        for j in 0..n 
            next.push(cost[j as usize]);
        
        for j in 0..flights.len() 
            if cost[(flights[j as usize][0]) as usize] != 9223372036854775807 
                next[(flights[j as usize][1]) as usize] = get_min(
                    next[(flights[j as usize][1]) as usize],
                    cost[(flights[j as usize][0]) as usize] + flights[j as usize][2],
                );
            
        
        cost = next;
    
    if cost[dst as usize] == 9223372036854775807 
        -1
     else 
        cost[dst as usize]
    


fn get_min(a: isize, b: isize) -> isize 
    if a < b 
        a
     else 
        b
    

执行结果如下:


左神java代码

以上是关于2022-04-28:有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,的主要内容,如果未能解决你的问题,请参考以下文章

leetcode_787K 站中转内最便宜的航班

浅谈 DFS(回溯算法)Dijkstra 算法Bellman-Ford 算法

CJOJ 免费航班

P4568 [JLOI2011]飞行路线

codevs 3971 航班

最少转机