线性dp_acwing

题目:最长公共子序列

897. 最长公共子序列 - AcWing题库

分析

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int n, m;
const int N = 1e3+10;
char a[N], b[N];
int dp[N][N];

int main() {
    cin >> n >> m >> a+1 >> b+1;
    
    for(int i = 1; i <= n; i ++) {
        for(int j = 1; j <= m; j ++) {
            dp[i][j] = max(dp[i-1][j],dp[i][j-1]);
            if(a[i]==b[j]) dp[i][j] = max(dp[i][j], dp[i-1][j-1]+1);
        }
    }
    
    cout << dp[n][m] << endl;
    return 0;
}
相关推荐
Jane-66677712 小时前
C语言——表达式、语句、函数
c语言·开发语言·算法
Tony_yitao12 小时前
12.华为OD机试 - N个选手比赛前三名、比赛(Java 双机位A卷 100分)
java·算法·华为od·algorithm
小龙报12 小时前
【算法通关指南:数据结构与算法篇】树形结构遍历指南:DFS 递归深搜与 BFS 队列广搜实战解析
c语言·数据结构·c++·算法·链表·深度优先·visual studio
业精于勤的牙12 小时前
浅谈:快递物流与算法的相关性(六)
算法
qq_4335545413 小时前
C++ 二维线性DP
c++·算法·图论
风筝在晴天搁浅13 小时前
代码随想录 115.不同的子序列
算法
c#上位机13 小时前
halcon2个区域合并为1个区域—union2
图像处理·算法·计算机视觉·halcon
程序员-King.13 小时前
双指针/滑动窗口—算法总结与教学指南
经验分享·算法·双指针
小武~13 小时前
Leetcode 每日一题C 语言版 -- 274 H-index
c语言·算法·leetcode
0 0 013 小时前
CCF-CSP 36-3 缓存模拟(cache)【C++】
开发语言·c++·算法