算法——图论:路径,回溯

. - 力扣(LeetCode)

给你一个有 n 个节点的 有向无环图(DAG),请你找出所有从节点 0 到节点 n-1 的路径并输出(不要求按特定顺序

 graph[i] 是一个从节点 i 可以访问的所有节点的列表(即从节点 i 到节点 graph[i][j]存在一条有向边)。

即给定邻接表求0到n-1的所有路径。

自己的代码:dfs,来到当前节点先记录其路径。如果发现当前节点为最后节点则直接返回。否则,对当前节点的每个邻接节点不断dfs。dfs完成后,将当前节点从路径中删除并返回。

注意:此题无需判断节点是否访问过,因为本题是有向图,对于某个节点,指向该节点可能有好几个节点,所以如果该节点只被访问一次无法得到所有路径。

class Solution {
public:vector<vector<int>>res;vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {vector<int> visited(graph.size(),0),path;dfs(graph,0,path,visited);return res;}void dfs(vector<vector<int>>& graph,int cur,vector<int> &path,vector<int>&visited){path.push_back(cur);if(cur==graph.size()-1){res.push_back(path);path.pop_back();return;}for(int i=0;i<graph[cur].size();i++){//if(!visited[graph[cur][i]])dfs(graph,graph[cur][i],path,visited);}//visited[cur]=1;path.pop_back();}
};

官方题解:

我们可以使用深度优先搜索的方式求出所有可能的路径。具体地,我们从 0 号点出发,使用栈记录路径上的点。每次我们遍历到点 n−1,就将栈中记录的路径加入到答案中。

特别地,因为本题中的图为有向无环图(DAG\text{DAG}DAG),搜索过程中不会反复遍历同一个点,因此我们无需判断当前点是否遍历过。

class Solution {
public:vector<vector<int>> ans;vector<int> stk;void dfs(vector<vector<int>>& graph, int x, int n) {if (x == n) {ans.push_back(stk);return;}for (auto& y : graph[x]) {stk.push_back(y);dfs(graph, y, n);stk.pop_back();}}vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {stk.push_back(0);dfs(graph, 0, graph.size() - 1);return ans;}
};

整体思路差不多。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/778747.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GEE训练——如何实现单景影像边界的提取以sentinel和Landsat数据为例(栅格转矢量)

本教程的主要目的是如何实现单景影像边界的提取以sentinel和Landsat数据为例,很多人是项通过GEE来实现单景影像的获取过程,所以这里最重要的就是首先根据点确定影像的范围,或者根据指定的单景影像的编号来获取指定的单景影像,然后将其矢量化即可。 简介 在Google Earth E…

mysql8.x在windows server2019安装并设置主从同步难点问题

1.MySQL服务无法启动并提示“MySQL8.x本地计算机上的MySQL服务启动后停止” 1&#xff09;用notepad打开my.ini文件&#xff0c;重新保存为ansi编码格式。 2&#xff09;右键windows图标&#xff0c;点击“计算机管理”&#xff0c;点击“本地用户和组”&#xff0c;双击“组…

JSP技术及其应用

目录 一、JSP 指令元素 1. page指令 二、JSP 注释 1. HTML注释&#xff1a; 2. Java注释&#xff1a; 3. JSP注释&#xff1a; 三、页面编码格式 1. pageEncoding&#xff1a; 2. contentType&#xff1a; 一、JSP 指令元素 JSP包含三种主要的指令元素&#xff1a;pag…

SQL-CRUD-2数据库实验

目录 第一关任务描述 相关知识 插入完整内容的行 插入选定内容的行 编程要求 测试说明 第一关代码 第二关任务描述 相关知识 删除表中的指定行 删除表中的所有行 编程要求 测试说明 第二关代码 第三关任务描述 相关知识 更新表中的指定行 编程要求 测试说明…

【Pytorch入门】小土堆PyTorch入门教程完整学习笔记(详细笔记并附练习代码 ipynb文件)

小土堆PyTorch入门教程笔记 最近在观看PyTorch深度学习快速入门教程&#xff08;绝对通俗易懂&#xff01;&#xff09;【小土堆】顺便做点笔记&#xff0c;方便回看&#xff0c;同时也希望记录的笔记能够帮助到更多在入门的小伙伴~ 【注】仅记录个人觉得重要的知识&#xff0c…

cas学习2:idea里搭建cas项目

在上篇中介绍了cas服务在tomcat中怎么启动的及某j集成cas&#xff0c;这篇讲下idea怎么集成cas成一个项目&#xff0c;为后续的定制自己的项目做好铺垫。 1.下载CAS 模板 Overlay Template&#xff0c;我这里使用 Apereo CAS 5.3 版本&#xff0c;JDK需要1.8 地址&#xff1a…

JavaWeb后端——HTTP协议/Tomcat

HTTP HTTP协议&#xff1a;无状态&#xff0c;对事务处理没有记忆能力。每次请求-响应都是独立的。后一次请求不会记录前一次请求数据。缺点&#xff1a;多次请求之间不能共享数据&#xff0c;优点&#xff1a;速度快。 HTTP协议请求报文&#xff1a; HTTP协议响应报文&#x…

分布式算法 - 雪花算法

雪花算法是一种用于生成全局唯一ID的分布式算法&#xff0c;用于解决分布式系统中生成唯一ID的需求。 雪花算法的核心思想是将生成的ID分为不同的部分&#xff0c;每个部分代表不同的含义。通常情况下&#xff0c;一个雪花 ID由3个部分组成&#xff1a; 时间戳&#xff1a;时…

JVM篇详细分析

JVM总体图 程序计数器&#xff1a; 线程私有的&#xff0c;每个线程一份&#xff0c;内部保存字节码的行号&#xff0c;用于记录正在执行字节码指令的地址。&#xff08;可通过javap -v XX.class命令查看&#xff09; java堆&#xff1a; 线程共享的区域&#xff0c;用来保存对…

Java中的基本数据与运算(关键字、标识符、运算符)

目录 一、关键字 二、标识符 三、注释 四、变量 五、数据类型 六、运算符 6.1 算术运算符 6.2 比较运算符 6.3 逻辑运算符 6.4 位移运算符 一、关键字 在 Java 中内置了很多有特殊意义的单词&#xff0c;这些单词不能做为类名、方法名、变量名来使用。关键字必须是小…

Calendar日历类

Calendar 类是一个抽象类&#xff0c;为我们提供了关于日期计算的功能&#xff0c;比如&#xff1a;年、月、日、时、分、秒的展示和计算。 GregorianCalendar 是Canlendar 的子类&#xff0c;表示公历。 注&#xff1a;月份的表示&#xff0c;一月是0&#xff0c;二月是1&am…

【echart】数据可视化+vue+vite遇到问题

1、vue3使用echars图表报错&#xff1a;"Initialize failed:invalid dom" 原因是因为&#xff1a;Dom没有完成加载时&#xff0c;echarts.init() 就已经开始执行了&#xff0c;获取不到Dom&#xff0c;无法进行操作 解决&#xff1a;加个延时 onMounted(async () …

Elasticsearch相关问题

相关问题&#xff1a; 1、Elasticsearch.Net和NEST的区别&#xff1f; Elasticsearch 官方为 .NET 提供了 2 个官方客户端库&#xff1a;Elasticsearch.Net 和 NEST。 Elasticsearch.Net 和 NEST对比说明&#xff1a; 可以简单理解为 Elasticsearch.Net 是 NEST的一个子集。N…

MATLAB:优化与规划问题

一、线性规划 % 线性规划&#xff08;Linear programming, 简称LP&#xff09; fcoff -[75 120 90 105]; % 目标函数系数向量 A [9 4 7 54 5 6 105 10 8 53 8 9 77 6 4 8]; % 约束不等式系数矩阵 b [3600 2900 3000 2800 2200]; % 约束不等式右端向量 Aeq []; % 约束等式系…

实验2-spark编程

实验目的 &#xff08;1&#xff09;通过实验掌握Spark的基本编程方法&#xff1b; &#xff08;2&#xff09;熟悉RDD到DataFrame的转化方法&#xff1b; &#xff08;3&#xff09;熟悉利用Spark管理来自不同数据源的数据。 实验内容 1&#xff0e;Spark基本操作 请参照…

[TS面试]TS中如何设计Class声明

TS中如何设计Class声明 class Greeter{greeting: string;constructor(message:string){this.greeting message}getGreeting():string{return this.greeting}sayGreeting():string{return Say ${this.greeting}} } const greeter new Greeter(Hello)

ROUYI框架地址

1、原版系统地址与文档 https://gitee.com/dromara/RuoYi-Cloud-Plus?_fromgitee_search 源码地址 https://plus-doc.dromara.org/#/ruoyi-cloud-plus/home 后端地址 https://plus-doc.dromara.org/#/plus-ui/home 前端地址 前端代码地址&#xff1a; RuoYi-Vue-Plus: 多租户…

maven的依赖继承

先说一下创建子maven工程的步骤 继承 继承的作用&#xff1a;在父工程中&#xff0c;统一管理项目中的依赖信息&#xff0c;进行统一的版本控制 继承的背景是&#xff1a;对一个大型的项目进行了模块拆分&#xff0c;一个project下&#xff0c;创建了很多的module&#xff0c…

东特科技现已加入2024第13届国际生物发酵产品与技术装备展

参展企业介绍 温州东特科技有限公司是一家集设计、生产、销售及服务为一体的卫生级流体设备企业。专业从事各种乳食品、制药、化工、啤酒设备、不锈钢卫生级阀门&#xff0c;管件&#xff0c;视镜&#xff0c;及非标配件定制等产品的销售与服务。先进的设计理念专业的技术优势一…

为啥从我激情满满的要做前端开发,到现在不断的怀疑自己能不能学会?

一开始&#xff0c;我对前端开发充满了热情和期待&#xff0c;认为只要努力就能掌握那些看似复杂的技能&#xff0c;比如HTML、CSS和JavaScript等基础技能&#xff0c;就能够构建出功能丰富、交互性强的网页应用。 然而&#xff0c;随着学习的深入&#xff0c;我发现前端开发远…