关于动态规划【力扣1143.最长公共子序列的思考】

1、与前几题的区别

【力扣300.最长递增子序列】一个数组,不连续

【力扣674.最长连续递增子序列】一个数组,连续

【力扣718.最长重复子数组】两个数组,连续

【力扣1143.最长公共子序列】两个数组,不连续

(本题是求两个数组不连续的最长公共子序列的长度)

整体代码如下图所示

2、递推公式

本题与上一题的关键区别在于要求两个数组"不连续"的最长公共子序列的长度。当前位置dpij的状态来自三个方向。

(因为要求不连续的,所以只要有一样的就可以把状态转移给下一个)

【本题】递推公式部分的代码如下图所示

【上一题】要求的是连续的,当前位置dpij的状态来自一个方向:左上角。

(因为要求连续的所以必须前一个是连续的,才可以把状态转移给下一个。如果前一个不一样,当前的一样,就要重新开始计算)

递推公式部分的代码如下图所示

3、返回值

dp数组里的每个值,要么从左上角加1得到,要么是上方或左方元素的最大值,所以最大值一定出现在右下角,所以返回dptext1.size()text2.size()就好。

(dptext1.size()text2.size()表示以text1.size()-1和text2.size()-1为结尾的最长公共子序列的长度)

相关推荐
剑挑星河月1 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav2 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏2 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
星空露珠3 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字3 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
手写码匠3 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc
luj_17683 小时前
草酸与烟酸对消化及糖代谢的影响解析
服务器·c语言·开发语言·经验分享·算法
青风973 小时前
16-ADAPTRACK:基于自适应阈值的多目标跟踪匹配算法
人工智能·算法·目标跟踪
汤姆yu4 小时前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot