python实现最长公共子串

python实现最长公共子串

import numpy as np

def longest_substring(str1,str2):
    # 首先创建一个长宽分别为len(str1),len(str2)的二维数组
    record = np.zeros(shape=(len(str1),len(str2)))
    # 获取第一个字符串的长度
    str1_length = len(str1)
    # 获取第二个字符串的长度
    str2_length = len(str2)
    # 最大长度
    maxLen = 0
    # 结束的索引
    maxEnd = 0
    for i in range(str1_length):
        for j in range(str2_length):
            # 判断两个字符串对应的索引是否相同
            if str1[i] == str2[j]:
                # 判断是否是第一行或者是第一列
                if i==0 or j==0:
                    # 如果是则对应索引置一
                    record[i][j] = 1
                else:
                    # 如果不是对应的索引则为其左上角对应的元素加一
                    record[i][j] = record[i-1][j-1]+1
            else:
                # 如果字符串对应的元素不相同则置零
                record[i][j] = 0
            # 判断记录数值是否大于最大长度
            if record[i][j] > maxLen:
                # 如果是则充值最大长度
                maxLen = record[i][j]
                # 将结束索引置为i
                maxEnd = i
    print(record)
    # 返回结果为,起始的索引及最大的长度
    return maxEnd-maxLen+1,maxLen
str1 = 'acbcbcef'
str2 = 'abcbced'
x_start,maxLen = longest_substring(str1,str2)
print(x_start,maxLen)

原理及c实现可以参照下面链接

https://blog.csdn.net/qq_25800311/article/details/81607168

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值