首页 > 编程 > Python > 正文

python实现求两个字符串的最长公共子串方法

2020-02-15 22:28:18
字体:
来源:转载
供稿:网友

如下所示:

# coding:utf-8'''求两个字符串的最长公共子串思想:建立一个二维数组,保存连续位相同与否的状态''' def getNumofCommonSubstr(str1, str2):  lstr1 = len(str1) lstr2 = len(str2) record = [[0 for i in range(lstr2+1)] for j in range(lstr1+1)] # 多一位 maxNum = 0   # 最长匹配长度 p = 0    # 匹配的起始位  for i in range(lstr1):  for j in range(lstr2):   if str1[i] == str2[j]:    # 相同则累加    record[i+1][j+1] = record[i][j] + 1    if record[i+1][j+1] > maxNum:     # 获取最大匹配长度     maxNum = record[i+1][j+1]     # 记录最大匹配长度的终止位置     p = i + 1 return str1[p-maxNum:p], maxNum  if __name__ == '__main__': str1 = raw_input() str2 = raw_input()  res = getNumofCommonSubstr(str1, str2) print res

输出结果:字符串str1中的第一个最长公共子串(若有重复)

以上这篇python实现求两个字符串的最长公共子串方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林站长站。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表