LCS(最长公共子串) python3实现

本文详细介绍了如何使用 Python3 实现经典的 LCS(最长公共子串)算法,通过动态规划方法解决该问题,适用于字符串比较和序列分析等场景。
摘要由CSDN通过智能技术生成
	LCS问题就是求两个字符串最大相同的公共子串;我们现假设有两个字符串X,Y。其长度分别为m,n
	我们从X,Y两个字符串的最后一个字符串开始看起
	如果  Xm = Yn:
	LCS(X, Y) = LCS(Xm-1, Yn-1)+ "Xm"
	如果Xm != Yn:
	LCS(X,Y) = max(LCS(Xm-1,Yn), LCS(Xm, Yn-1))
	我们即构建了这样的动态转移方程。如果还不是特别明白,我们来看以下例子。
在这里插入图片描述
	有了上述的动态转移方程,我们该如何编写代码呢?
	我们采用递归加备忘录的方式,基于刚刚的动态转移方程我们设置一个二维数组用来
	存放当前最长的公共子串。我们可得到以下递推式。

| 在这里插入图片描述

				对于下列两个字符串,其产生的二维数组如下。
xi A B A B A C A B
yi 0 0 0 0 0 0</
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值