news 2026/5/14 16:06:33

算法杂谈:回溯路线

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法杂谈:回溯路线

目录

前言

在动态规划中:

在bfs中:


前言

对于普通的路线问题,我们可以存储全局变量path存储路线过程中的,一个个“点”。由于这些点就是按照顺序存储的,路线就是可以直接得到的。

但是如果是动态规划,或者是带有图需要从一个点开始找到另一个点,我们在找到结果后还需要回溯这个结果的实现路线,这里没办法轻松得到路线,那么我们就需要尽可能利用条件,从该结果往回退找到上一个节点是什么,这里介绍两种目前已经遇到的情景。

在动态规划中:

以牛客网 最长公共子序列II 为例

最长公共子序列(二)_牛客题霸_牛客网

找到最长子序列,我们还需要返回这个子序列是什么,既然我们已经完成填表,那么我们就可以,以dp值为引,按照dp值递减的顺序,修改i和j的坐标,当s1[i]==s2[j]时此时这个就是我们要寻找的节点,头插进结果,让i--,j--(意味着继续道s1[0,i-1],s2[0,j-2]区间内寻找);如果不等,往可以使dp值减少的方向前进,于是我们就找到了路线。

代码实现如下:

class Solution { public: string LCS(string s1, string s2) { int n=s1.length(),m=s2.size(); s1=' '+s1,s2=' '+s2; vector<vector<int>> dp(n+1,vector<int>(m+1)); for(int i=1;i<=n;++i) { for(int j=1;j<=m;++j) { if(s1[i]==s2[j])dp[i][j]=dp[i-1][j-1]+1; else dp[i][j]=max(dp[i-1][j],dp[i][j-1]); } } //回溯构造LCS string ret; int i=n,j=m; while(i&&j) { if(s1[i]==s2[j]) { ret=s1[i]+ret; --i; --j; } else if(dp[i-1][j]>dp[i][j-1])--i; else --j; } return ret==""?"-1":ret; } };

在bfs中:

以bjfuoj的 码码,我迷路了 为例

BJFUOJ | 码码,我迷路了

该题是一道很简单的bfs经典题,但找到目标点后,我们还需要输出从起点到目标点依次经过的路径,此时依旧利用回溯,构造路线。

回溯路线:因为我们需要从一个节点得到上一个节点的信息,这里节点的信息就是对应的坐标,那么我们可以创建一个“point”类型的二维数组fa,用fa[i][j]存储到达点{i,j}的上一个节点的坐标,具体代码体现就是在bfs中队列push新节点的时候,我们得到的节点假设是{newx,newy},因为newx和newy是由{x,y}得到的,我们使fa[newx][newy]={x,y}这样就得到了上一个节点的位置,就可以实现回溯了。

此篇完。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 13:24:07

Langchain-Chatchat如何处理嵌套引用?复杂文档结构解析

Langchain-Chatchat如何处理嵌套引用&#xff1f;复杂文档结构解析 在企业知识库系统日益普及的今天&#xff0c;一个核心挑战浮出水面&#xff1a;如何让AI真正“读懂”那些充满脚注、交叉引用和层级结构的专业文档&#xff1f;比如一份科研报告中写着“详见[1]”&#xff0c;…

作者头像 李华
网站建设 2026/5/13 15:50:27

Langchain-Chatchat开源项目实战:构建企业级知识库问答系统

Langchain-Chatchat开源项目实战&#xff1a;构建企业级知识库问答系统 在企业数字化转型的浪潮中&#xff0c;一个现实而紧迫的问题日益凸显&#xff1a;海量文档沉睡在共享盘、邮箱和员工电脑里&#xff0c;真正需要时却“看得见、找不到、用不上”。新员工入职培训耗时数周&…

作者头像 李华
网站建设 2026/5/12 18:40:45

SpringSecurity源码剖析

过滤器链加载源码spring boot启动中会加载spring.factories文件&#xff0c;在文件中有对应Spring Security的过滤器链的配置信息。# 安全过滤器自动配置 org.springframework.boot.autoconfigure.security.servlet.SecurityFilterAutoCo nfigurationSecurityFilterAutoConfigu…

作者头像 李华
网站建设 2026/5/13 15:51:46

Maxwell数据变更捕获工具简介

目录 引入Maxwell 相关概念 Maxwell概念 MySQL主从复制 binlog模式 Maxwell工作原理 Maxwell操作 增量数据同步 历史数据全量同步 Maxwell安装配置 MySQL环境配置 Maxwell安装与配置 Maxwell流程示例 引入Maxwell 在数据驱动的业务场景中&#xff0c;经常需要实时…

作者头像 李华
网站建设 2026/5/13 11:46:08

AI开发工具实战体验:CodeBuddy与Trae的得与失

文章目录引言一、核心优势&#xff1a;开发效率的革命性提升二、现存痛点&#xff1a;AI生成的"幻觉"问题三、高效使用策略&#xff1a;人机协作的最佳实践四、未来展望&#xff1a;AI开发工具的演进方向结语引言 在软件开发领域&#xff0c;AI辅助工具的兴起正在重…

作者头像 李华
网站建设 2026/5/14 11:42:58

Langchain-Chatchat问答系统冷热数据分离策略:降低成本开支

Langchain-Chatchat问答系统冷热数据分离策略&#xff1a;降低成本开支 在企业知识库日益膨胀的今天&#xff0c;一个现实问题摆在面前&#xff1a;我们花了大量资源部署了基于大模型的本地问答系统&#xff0c;文档也全都向量化存进了高性能向量数据库&#xff0c;可为什么查询…

作者头像 李华