描述
给定两个字符串str1和str2,输出两个字符串的最长公共子串
题目保证str1和str2的最长公共子串存在且唯一。
示例1
输入:
"abc1234321ab",12
复制返回值:
7
解题思路:
动态规划:
思路一,dp[i][j]代表最大字符串长度,定义时建立为数字的矩阵,通过索引切片得出公共子串
dp[i][j]表示字符串str1中第i个字符和str2种第j个字符为最后一个元素所构成的最长公共子串。如果要求dp[i][j],也就是str1的第i个字符和str2的第j个字符为最后一个元素所构成的最长公共子串,我们首先需要判断这两个字符是否相等。
-
如果不相等,那么他们就不能构成公共子串,也就是
dp[i][j]=0; -
如果相等,我们还需要计算前面相等字符的个数,其实就是dp[i-1][j-1],所以
dp[i][j]=dp[i-1][j-1]+1; -
再使用res记录最长的连续子串的长度,index记录最长连续子串末尾的序号:
-
class Solution:
def LCS(self , str1 , str2 ):
# write code here
m=len(str1)
n=len(str2)
dp = [[0]*(n+1) for j in range(m+1)]
#######定义dp矩阵时,输入笔误,行和列值定义取翻,