python求最长公共子串_Python 寻找最长公共子串的简单示例

这篇文章主要为大家详细介绍了Python 寻找最长公共子串的简单示例,具有一定的参考价值,可以用来参考一下。

感兴趣Python 寻找最长公共子串的简单示例的小伙伴,下面一起跟随512笔记的小编罗X来看看吧。

# 512笔记网 (www.512pic.com)

def find_lcp(s,t):

lens = len(s)

lent = len(t)

if not lens or not lent:

return 0

longest = 0

for i in range(lens):

for j in range(lent):

length = 0

m = i

n = j

while m < lens and n < lent:

if s[m] != t[n]:

break

length += 1 #相等则两个字符串均向后移动一位

m += 1

n += 1

if longest < length:

sub =''

sub += s[m-length:m] #或者sub += t[n-length:n]

longest = length

return longest,sub

if __name__ == '__main__':

print(find_lcp('abcdefg','aabcabcd')) #(4, 'abcd')

# End 512.笔记 www.512pic.com上述的实现方法对s和t串进行逐个字符比较,其中循环有三层,复杂度为o(n^3),《大话数据结构》里有一个逐步改进的KMP算法,以后再补充吧

注:关于Python 寻找最长公共子串的简单示例的内容就先介绍到这里,更多相关文章的可以留意512笔记的其他信息。

关键词:子串

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值