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 797:所有可能的路径 -> 正文阅读

[数据结构与算法]LeetCode 797:所有可能的路径

1. 题目描述

给定一个有 n 个节点的 有向无环图(DAG),请你找出所有从节点 0 到节点 n-1 的路径并输出(不要求按特定顺序)。
二维数组的第 i 个数组中的单元都表示有向图中 i 号节点所能到达的下一些节点,空就是没有下一个结点了。

输入:graph = [[1,2,3],[2],[3],[]]

输出:[[0,1,2,3],[0,2,3],[0,3]]

2. 题目分析

首先我们根据题目描述画出图,并分析输入输出,输入输出都是二维数组,根据题目描述,我们采用深度优先搜索遍历图,求出所有可能的路径。具体,可以从0号位置出发, 用栈记录路径上的点, 每次当我们找到最终位置后就将其加入到返回列表中;因为操作中不会反复遍历同一个点,所以我们不用标记该点,采用回溯思想即可。
在这里插入图片描述
代码分析

3. 代码实现

class Solution {
    //创建一张二维列表
    List<List<Integer>> ret = new LinkedList<>();
    //创建一个栈,用Deque类来实现
    Deque<Integer> stack = new ArrayDeque<>();
    
    public List<List<Integer>> allPathsSourceTarget(int[][] graph) {
        stack.offerLast(0); //这里必须使用offerLast哦,不然结果是反的,可以一试
        dfs(graph, 0, graph.length-1);
        return ret;
    }

    //dfs深度优先搜索遍历
    public void dfs(int[][] graph, int start, int end){
        if(start==end){
            ret.add(new ArrayList<Integer>(stack));//stack是什么,我就用stack去构造一个ArrayList()对象,将其中的每个元素都放到ArrayList里面
            return;
        }

        for(int x : graph[start]){
            stack.offerLast(x);
            dfs(graph, x, end);
            stack.pollLast();
        }
    }
    
}

4. 今日收获

①DFS深度优先搜索遍历代码实现
②使用Deque类实现栈,具体参考博客:Java双向队列Deque栈与队列

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

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 23:00:46-

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