动态规划dp中的子序列、子数组问题总结

59 篇文章 1 订阅 ¥9.90 ¥99.00
本文总结了动态规划中关于子序列和子数组的问题,包括定义dp数组、初始化、状态转移方程及最终结果。通过最长公共子序列、最长上升子序列等例子阐述了状态转移过程,并指出在难度提升时如何处理复杂操作,如编辑距离问题。最后列举了一些相关的题目供进一步练习。
摘要由CSDN通过智能技术生成

目录

定义dp数组

初始化dp数组

状态转移方程

最终结果

题目


定义dp数组

这类问题的共性是会提供两个数组,寻找他们共同的子序列、子数组。设第一个数组为s,第二个数组为t。则可以设二维dp数组,其大小为len(s + 1)*len(t + 1)

dp[i][j]表示 s 前 i 个长度,与 t 前 j 个长度进行比较

初始化dp数组

初始化时通常将dp[i][0]和dp[0][i]全设为0,表示长度为0时,比较结果为0

状态转移方程

dp[i][j] 一般可以由 dp[i-1][j], dp[i][j - 1]推出,或者由dp[i-1][j-1]推出

例:最长公共子序列:

if (text1[i - 1] == text2[j - 1]) //注意这里 比较的是i-1 j-1 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坠金

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值