IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> leetcode 787. Cheapest Flights Within K Stops | 787. K 站中转内最便宜的航班(BFS) -> 正文阅读

[数据结构与算法]leetcode 787. Cheapest Flights Within K Stops | 787. K 站中转内最便宜的航班(BFS)

题目

https://leetcode.com/problems/cheapest-flights-within-k-stops/
在这里插入图片描述

题解

这题挺坑的实际上。DFS 超时了,因为涉及到步数限制 k,所以并不能加缓存,然后去看了答案。
答案给了一种 BFS 解法,看完思路我就开始一顿写。

一开始是按照如果走回头路的开销比不走回头路更小的话,就走回头路这种思路来写的。提交的时候发现,能不能走回头路,这个问题会比较复杂。
回头路是可以走的,但是不能简单的用回头路的开销去覆盖原有的开销,因为在你走回头路的时候,3步到①可能比2步到①的实际开销更小,但你不能确定在之后剩余的步数中,哪种选择更好。

说白了就是,当你还不能确定要不要走重复路线的时候,一维的dist不能同时保存走或不走两种结果。
所以后来用了 int[2] 存储[i,从src到i的距离。详见注释吧。

最后,贴一下混乱的草稿。
在这里插入图片描述

class Solution {
    public int findCheapestPrice(int n, int[][] flights, int src, int dst, int k) {
        int[][] graph = new int[n][n];
        for (int i = 0; i < n; i++) {
            Arrays.fill(graph[i], -1);
        }
        for (int[] f : flights) {
            graph[f[0]][f[1]] = f[2];
        }
        // BFS
        int[] dist = new int[n]; // dist[i]表示src->i的距离
        Arrays.fill(dist, Integer.MAX_VALUE);
        dist[src] = 0;

        // 此处使用int[]的原因是,不能简单的从dist中拿最小结果,因为在你走回头路的时候,3步到①可能比2步到①的实际开销更小,
        // 但你不能确定在之后剩余的步数中,哪种选择更好。
        // 说白了就是,当你还不能确定要不要走重复路线的时候,一维的dist不能同时保存走或不走两种结果。
        Stack<int[]> stack = new Stack<>(); // [i,从src到i的距离]。
        stack.push(new int[]{src, 0});

        int step = 0;
        while (step++ <= k) {
            if (stack.isEmpty()) break;
            Stack<int[]> newStack = new Stack<>();
            while (!stack.isEmpty()) {
                int[] pair = stack.pop(); // pair = [i,从src到i的距离]
                int i = pair[0];
                for (int j = 0; j < n; j++) { // src->i->j
                    // 如果之前已经走过,只有当距离比原来小的时候才加入计算
                    // 如果之前没走过,则当前距离肯定比INF小,所以肯定会加入计算
                    if (i != j && graph[i][j] >= 0 && pair[1] + graph[i][j] < dist[j]) { 
                        dist[j] = pair[1] + graph[i][j];
                        newStack.add(new int[]{j, dist[j]});
                    }
                }
            }
            stack = newStack;
        }
        return dist[dst] == Integer.MAX_VALUE ? -1 : dist[dst];
    }
}

在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-18 16:14:34  更:2021-12-18 16:16:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 12:02:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码