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

时间:2021-05-22

如下所示:

# 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实现求两个字符串的最长公共子串方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章