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.youkuaiyun.com/qq_25800311/article/details/81607168