题解 | #最长公共子串#

最长公共子串

https://www.nowcoder.com/practice/f33f5adc55f444baa0e0ca87ad8a6aac

与最长公共子序列相似,只不过修改迭代条件即可,因为子串是连续额的,所以我们可以使用两个变量就可以截取出最长公共子串:

  • maxLen,记录最大公共子串长度
  • lastIdx,最长公共子串的结尾位置

class Solution {
public:
    
    string LCS(string str1, string str2) {
        int n = str1.size(), m = str2.size();
        vector<vector<int>> dp(n + 1, vector<int>(m + 1));
        int maxLen = 0;
        int lastIdx = -1;
        for(int i = 1; i <= n; i ++){
            for(int j = 1;j <= m;j ++){
                if(str1[i - 1] == str2[j - 1]){
                    dp[i][j] = dp[i - 1][j - 1] + 1;
                }else{
                    dp[i][j] = 0;
                }
                if(maxLen < dp[i][j]){
                    maxLen = dp[i][j];
                    lastIdx = i - 1;
                }
            }
        }

        return str1.substr(lastIdx - maxLen + 1, maxLen);
    }
};

全部评论

相关推荐

不愿透露姓名的神秘牛友
03-28 13:48
hory权:校招vip纯神人了,还说自己是什么师范大学的
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务