题解 | #最长公共子序列(二)#

最长公共子序列(二)

https://www.nowcoder.com/practice/6d29638c85bb4ffd80c020fe244baf11

class Solution {
  public:
    string LCS(string s1, string s2) {
        int n = s1.length(), m = s2.length();

        if (s1.empty() || s2.empty()) return "-1";

        vector<vector<int>> dp(n + 1, vector<int>(m + 1));
        string res;

        for(int i = 1; i <= n; ++ i){
            for(int j = 1; j <= m; ++ j){
                dp[i][j] = (s1[i - 1] == s2[j - 1]) ? 1 + dp[i- 1][j - 1] : max(dp[i][j - 1], dp[i - 1][j]);
            }
        }

        for(int i = n, j = m; dp[i][j] > 0; ){
            if(s1[i - 1] == s2[j - 1]){
                res += s1[i - 1];
                i --;
                j --;
            }else if(dp[i - 1][j] >= dp[i][j - 1]){
                i --;
            }else{
                j --;
            }
        }

        reverse(res.begin(), res.end());
        return res != "" ? res : "-1";

    }
};

全部评论

相关推荐

10-09 17:17
已编辑
门头沟学院 Java
活泼的代码渣渣在泡池...:同学你好,我也是学院本,后天要面这个亚信科技,是实习,请问问题都啥样呀,我项目就做了网上的,这是第一次面试
投递多益网络等公司10个岗位
点赞 评论 收藏
分享
牛客小菜鸡66:boss里面,招人的叫老板,找工作的叫牛人
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务