最长公共子序列(动态规划)

这篇博客详细介绍了最长公共子序列(LCS)的概念,通过动态规划的方法解析求解过程,包括二维数组的初始化、值的填充逻辑,以及最终如何反向查找和拼接相同字符。通过实例“BACD”和“CBDB”的动态规划图解,清晰展示了LCS的计算步骤,最大长度为2,从而得出两者之间的相似度。
摘要由CSDN通过智能技术生成

一)简介

最长公共子序列简称LCS,表示两个或多个序列中最长的子序列。

本质:用来寻找两个或多个序列(字符串)中最长的子序列,而子序列又可能是不连续的。

描述:两个或多个序列的“相似度

 

例如:“BACD” 和 “CBDB” 中最长的子序列是“BD”

           “AAABBBCCC” 和 “DDAAFFEBBECC” 中最长的子序列是“AABBCC”

 

二)动态规划图解

BACD”和“CBDB”相似度演示过程(填表):

 

第一步:初始化一个二维数组表格

 

第二步:因为B和C不相等,取左方向或上方向较大的值

 

第三步:因为B和B相等,取左上方的值在加1

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值