花与蛇1全集 影音,007幽灵党下载,天宫水西寺下一句
如下所示:
# 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实现求两个字符串的最长公共子串方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
python求numpy中array按列非零元素的平均值案例
网友评论