线性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;
}
相关推荐
星火开发设计几秒前
关联式容器:map 与 multimap 的键值对存储
java·开发语言·数据结构·c++·算法
散峰而望5 分钟前
【算法竞赛】二叉树
开发语言·数据结构·c++·算法·深度优先·动态规划·宽度优先
Never_Satisfied18 分钟前
在c#中,缩放jpg文件的尺寸
算法·c#
那起舞的日子23 分钟前
卡拉兹函数
java·算法
颜酱25 分钟前
滑动窗口算法通关指南:从模板到实战,搞定LeetCode高频题
javascript·后端·算法
Stringzhua26 分钟前
队列-双端队列【Queue2】
java·数据结构·算法·队列
侧岭灵风32 分钟前
yolov5颈部网络图解
深度学习·算法·yolo
夕除37 分钟前
js--21
java·python·算法
冬夜戏雪38 分钟前
单词拆分/分割等和子集
算法·leetcode·职场和发展
追随者永远是胜利者39 分钟前
(LeetCode-Hot100)21. 合并两个有序链表
java·算法·leetcode·链表·go