最长公共子串

Q: 求两个字符串的最长公共子串的长度
A:动态规划转移方程如下:
定义f[m][n] 为字符串A前m个字符和字符串B前n个字符的最长公共子串的长度,则

if A[m] != B[n]:
f[m][n] = max(f[m-1][n], f[m][n-1])
else if f[m-1][n-1] == 0:
f[m][n] = 1
else if f[m-2][n-2] + 1 == f[m-1][n-1]
f[m][n] = f[m-1][n-1] + 1
else:
f[m][n] = max(f[m-1][n], f[m][n-1])

转移方程稍显复杂,将f[m][n]定义为以A[m],B[n]结尾的公共子串长度,则要简单许多:

if A[m] != B[n]:
f[m][n] = 0
else:
f[m][n] = f[m-1][n-1] + 1

这样再遍历所有的F[m][n]即可求出最长公共子串长度

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值