最长公共子序列 Largest Common Subseqence

pecco

#include <bits/stdc++.h>
using namespace std;
const int N = 1005;
int dp[N][N];  // 可采用滚动数组优化 只保留i/i-1行
string s, t;
int main() {
    while (cin >> s >> t) {
        int ns = s.length(), nt = t.length();
        for (int i = 1; i <= ns; ++i) {
            for (int j = 1; j <= nt; ++j) {
                if (s[i - 1] == t[j - 1])
                    dp[i][j] = dp[i - 1][j - 1] + 1;
                else
                    dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
            }
        }
        cout << dp[ns][nt] << '\n';
    }
    return 0;
}

图片说明 图片说明

算法竞赛之路 文章被收录于专栏

整理、记录算法竞赛的好题

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-04 18:02
好不容易拿到了字节Offer,鼠鼠做后端的,但家里人觉得可能被裁员不稳定,让鼠鼠去投国企,现在好纠结到底该咋选
文档传偷助手:该投就投吧,不过建议别放弃offer 拿到手里的才是最好的
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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