最长公共子序列【东北大学oj数据结构10-3】C++

题面

对于给定两个序列 X 和 Y , 序列 Z 是 X 和 Y 的公共子序列是指如果 Z 同时是 X 和 Y 的子序列。

例如:如果 X = {a, b, c, b, d, a, b} 和 Y = {b, d, c, a, b, a} ,

那么序列 {b, c, a} 是 X 和 Y 的一个公共子序列。

但是序列 { b , c, a } 不是 X 和 Y 的最长公共子序列(LCS) , 因为它的长度是3。

而序列 {b,c,b,a} ( X 和 Y 都有这个序列)的长度是 4, 又没有长度大于或等于 5 的公共子序列,所以序列 {b,c,b,a} 是 X 和 Y 的最长公共子序列。

编写一个程序,找出给定的两个序列 X 和 Y 的LCS的长度。

输入

输入由多个数据集组成。

在第一行中,给出了一个整数 q,它是数据集的数量。

在下面的 2 × q 行中,给出了由两个序列 X 和 Y 组成的每个数据集。

输出

对于每个数据集,在一行中打印 X 和 Y 的 LCS 长度。

约束

1≤q≤150

1≤X和Y的长度≤1000

如果数据集包含长度大于100的序列,则Q≤20

输入样例

3

abcbdab

bdcaba

abc

abc

abc

bc

输出样例

4

3

2

代码
cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
 
using namespace std;
 
int main() {
    int n;
    cin >> n;
    for(int i=0;i<n;i++)
    {
        string a;
        string b;
        cin>>a>>b;
        int x=a.size();
        int y=b.size();
        vector<vector<int> > dq(x+1,vector<int>(y+1,0));
        for(int j=0;j<x;j++)
        {
            for(int k=0;k<y;k++)
            {
                if(a[j]==b[k])
                {
                    dq[j+1][k+1]=dq[j][k]+1;
                }
                else
                {
                    dq[j+1][k+1]=max(dq[j+1][k],dq[j][k+1]);
                }
            }
        }
        cout<<dq[x][y]<<endl;
    }
    return 0;
}
相关推荐
ghie90901 分钟前
基于MATLAB的遗传算法优化支持向量机实现
算法·支持向量机·matlab
CryptoRzz6 分钟前
欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
java·服务器·开发语言·数据库·区块链
Never_Satisfied28 分钟前
在JavaScript / HTML中,div容器在内容过多时不显示超出的部分
开发语言·javascript·html
朝新_36 分钟前
【优选算法】第一弹——双指针(上)
算法
艾莉丝努力练剑1 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
胡萝卜3.01 小时前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现
kyle~1 小时前
计算机系统---CPU的进程与线程处理
linux·服务器·c语言·c++·操作系统·计算机系统
CoovallyAIHub1 小时前
ICLR 2026 惊现 SAM 3,匿名提交,实现“概念分割”,CV领域再迎颠覆性突破?
深度学习·算法·计算机视觉
IT古董1 小时前
【第五章:计算机视觉-计算机视觉在工业制造领域中的应用】1.工业缺陷分割-(2)BiseNet系列算法详解
算法·计算机视觉·制造
电鱼智能的电小鱼1 小时前
服装制造企业痛点解决方案:EFISH-SBC-RK3588 预测性维护方案
网络·人工智能·嵌入式硬件·算法·制造