当前位置: 首页 > news >正文

《算法笔记》11.4小节——动态规划专题->最长公共子序列(LCS) 问题 A: 最长公共子序列

题目描述

给你一个序列X和另一个序列Z,当Z中的所有元素都在X中存在,并且在X中的下标顺序是严格递增的,那么就把Z叫做X的子序列。
例如:Z=<a,b,f,c>是序列X=<a,b,c,f,b,c>的一个子序列,Z中的元素在X中的下标序列为<1,2,4,6>。
现给你两个序列X和Y,请问它们的最长公共子序列的长度是多少?

输入

输入包含多组测试数据。每组输入占一行,为两个字符串,由若干个空格分隔。每个字符串的长度不超过100。

输出

对于每组输入,输出两个字符串的最长公共子序列的长度。

样例输入 复制
abcfbc abfcab
programming contest 
abcd mnp
样例输出 复制
4
2
0

分析:不妨设现在是第一个串 s1 的第 i 位,与第二个串 s2 的第 j 位在进行比较。

当 s1[i] == s2[j] 时,可以继续比较 i+1 和 j+1位,最长公共子序列长度 +1。

当 s1[i] != s2[j] 时,问题转化为比较 s1[i-1] 和 s2[j], 以及 s1[i] 和 s2[j-1],答案取这两个中的较大值。

#include<algorithm>
#include <iostream>
#include  <cstdlib>
#include  <cstring>
#include   <string>
#include   <vector>
#include   <cstdio>
#include    <queue>
#include    <stack>
#include    <ctime>
#include    <cmath>
#include      <map>
#include      <set>
#define INF 0x3fffffff
#define db1(x) cout<<#x<<"="<<(x)<<endl
#define db2(x,y) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<endl
#define db3(x,y,z) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<endl
#define db4(x,y,z,r) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<", "<<#r<<"="<<(r)<<endl
#define db5(x,y,z,r,w) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<", "<<#r<<"="<<(r)<<", "<<#w<<"="<<(w)<<endl
using namespace std;int main(void)
{#ifdef testfreopen("in.txt","r",stdin);
//    freopen("out.txt","w",stdout);clock_t start=clock();#endif //testchar s1[110],s2[110];while(~scanf("%s%s",s1+1,s2+1)){int l1,l2;l1=l2=0;int dp[110][110];for(int i=1;s1[i];++i,++l1)dp[i][0]=0;for(int j=1;s2[j];++j,++l2)dp[0][j]=0;dp[0][0]=0;for(int i=1;s1[i];++i){for(int j=1;s2[j];++j){if(s1[i]==s2[j])dp[i][j]=dp[i-1][j-1]+1;else dp[i][j]=max(dp[i-1][j],dp[i][j-1]);}}printf("%d\n",dp[l1][l2]);}#ifdef testclockid_t end=clock();double endtime=(double)(end-start)/CLOCKS_PER_SEC;printf("\n\n\n\n\n");cout<<"Total time:"<<endtime<<"s"<<endl;        //s为单位cout<<"Total time:"<<endtime*1000<<"ms"<<endl;    //ms为单位#endif //testreturn 0;
}

相关文章:

  • [Web服务器对决] Nginx vs. Apache vs. LiteSpeed:2025年性能、功能与适用场景深度对比
  • 双指针法高效解决「移除元素」问题
  • 机器学习10-随机森林
  • [SpringBoot]Spring MVC(5.0)----留言板
  • 算法与数据结构:质数、互质判定和裴蜀定理
  • React 常见的陷阱之(如异步访问事件对象)
  • AI驱动发展——高能受邀参加华为2025广东新质生产力创新峰会
  • 榕壹云上门家政系统:基于Spring Boot+MySQL+UniApp的全能解决方案
  • uniapp如何设置uni.request可变请求ip地址
  • 高等数学笔记——向量代数与空间解析几何1
  • [概率论基本概念1]什么是经验分布
  • 蓝桥杯2114 李白打酒加强版
  • 塔式服务器都有哪些重要功能?
  • 大型商业综合体AI智能保洁管理系统:开启智能保洁新时代
  • Zenmap代理情况下无法扫描ip
  • VMWare清理后,残留服务删除方案详解
  • 数据结构测试模拟题(1)
  • ES 调优帖:关于索引合并参数 index.merge.policy.deletePctAllowed 的取值优化
  • form-create-designer中$inject参数的数据结构及各项属性说明
  • 面向未来,遨游推出5G-A智能对讲机等系列终端
  • “世界茶树原产地”打通全产业链,茶文旅融合助力西双版纳高质量发展
  • 阳朔兴坪镇:在建乾元桥“垮塌”是谣言,系降雨导致工程挡土墙倾斜
  • 韩国总统选举白热化进行中,中韩青年民间交流促两国友好往来
  • 66岁华仁世纪集团有限公司创始人、董事长梁福东逝世
  • 交通运输局男子与两名女子办婚礼?官方通报:未登记结婚,开除该男子
  • 高温最强时段来了!北方局地高温有明显极端性