题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1006

题意:中文题诶~

思路:最长公共子序列模板题~

我们用dp[i][j]表示到a串第i个字符, b串第j个字符的最大匹配字符数,那么状态转移方程为:

dp[i][j]=dp[i-1][j-1]+1      a[i]==b[j]

dp[i][j]=max(dp[i][j-1], dp[i-1][j])   a[i]!=b[j]

我们可以这样理解:dp[i][j]表示第a串前i个字符与b串前j个字符的最大匹配数,dp[i-1][j-1]表示a字符前i-1个字符与b串前j-1个字符的最大匹配数

如果a[i]=b[j],那么很明显dp[i][j]=dp[i-1][j-1]+1;

若a[i]!=b[j],我们假设a, b的最大匹配串为c,显然a[i], b[j]不能同时作为c的最后一个字符,那么最优匹配情况即为a[i]为c的最后一个字符或者b[j]为c的最后一个字符(这点不大好理解),即:

dp[i][j]=dp[i][j-1]    a[i]是c的最后一个字符即匹配的末尾字符

dp[i][j]=dp[i-1][j]    b[j]是c的最后一个字符即匹配的末尾字符 (其实当a[i], b[j]都不是c的最后一个字符时即a[i], b[j]都不匹配时dp[i][j]=dp[i-1][j-1])

又dp要取最大值 ,即dp[i][j]=max(dp[i][j-1], dp[i-1][j])

题目还要求要输出一个最优匹配串,这个我们用vis[][]数组在dp过程中记录一下路径就好啦~

代码1:非递归取出路径

 #include <bits/stdc++.h>
#define MAXN 1010
using namespace std; int jj=, vis[MAXN][MAXN];
char gg[MAXN], a[MAXN], b[MAXN]; void getlcs(int i, int j){ //**逆推取出vis中保存的路径
while(i>&&j>){
if(vis[i][j]==){
gg[jj++]=a[i-]; //**将路径存储在gg数组中
i--;
j--;
}else if(vis[i][j]==){
j--;
}else if(vis[i][j]==){
i--;
}
}
gg[jj]='\0';
} int main(void){
int dp[MAXN][MAXN];
scanf("%s%s", a, b);
int lena=strlen(a);
int lenb=strlen(b);
memset(vis, , sizeof(vis));
memset(dp, , sizeof(dp));
for(int i=; i<=lena; i++){
for(int j=; j<=lenb; j++){
if(a[i-]==b[j-]){
dp[i][j]=dp[i-][j-]+;
vis[i][j]=; //**vis标记路径
}else if(dp[i][j-]>dp[i-][j]){
dp[i][j]=dp[i][j-];
vis[i][j]=;
}else{
dp[i][j]=dp[i-][j];
vis[i][j]=;
}
}
}
getlcs(lena, lenb);
for(int i=jj-; i>=; i--){ //**输出路径
printf("%c", gg[i]);
}
printf("\n");
return ;
}

代码2: 递归输出路径

 #include <bits/stdc++.h>
#define MAXN 1010
using namespace std; int jj=, vis[MAXN][MAXN];
char a[MAXN], b[MAXN]; void getlcs(int i, int j){ //**输出路径
if(!i||!j){
return;
}
if(vis[i][j]==){
getlcs(i-, j-);
printf("%c", a[i-]);
}else if(vis[i][j]==){
getlcs(i, j-);
}else{
getlcs(i-, j);
}
} int main(void){
int dp[MAXN][MAXN];
scanf("%s%s", a, b);
int lena=strlen(a);
int lenb=strlen(b);
memset(vis, , sizeof(vis));
memset(dp, , sizeof(dp));
for(int i=; i<=lena; i++){
for(int j=; j<=lenb; j++){
if(a[i-]==b[j-]){
dp[i][j]=dp[i-][j-]+;
vis[i][j]=; //**vis标记路径
}else if(dp[i][j-]>dp[i-][j]){
dp[i][j]=dp[i][j-];
vis[i][j]=;
}else{
dp[i][j]=dp[i-][j];
vis[i][j]=;
}
}
}
getlcs(lena, lenb);
printf("\n");
return ;
}

51nod1006(lcs)的更多相关文章

  1. 51Nod--1006 lcs

    1006 最长公共子序列Lcs 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). ...

  2. 51nod--1006 最长公共子序列Lcs (动态规划)

    题目: 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个 ...

  3. 51nod1006 -最长公共子序列Lcs【动态规划】

    给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符串最 ...

  4. 51Nod-1006 最长公共子序列Lcs

    题目链接 Description 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca ...

  5. 51Nod-1006【LCS】+【输出路径】模板题

    题目链接:https://vjudge.net/contest/225715#problem/B 转载于>>> 题目大意: 给出两个序列,要求输出它们的最长公共子序列. 解题思路: ...

  6. 最长公共子序列lcs 51nod1006

    推荐参考博客:动态规划基础篇之最长公共子序列问题 - CSDN博客  https://blog.csdn.net/lz161530245/article/details/76943991 个人觉得上面 ...

  7. 我的第一篇博客----LCS学习笔记

    LCS引论 在这篇博文中,博主要给大家讲一个算法----最长公共子序列(LCS)算法.我最初接触这个算法是在高中学信息学竞赛的时候.那时候花了好长时间理解这个算法.老师经常说,这种算法是母算法,即从这 ...

  8. 动态规划之最长公共子序列(LCS)

    转自:http://segmentfault.com/blog/exploring/ LCS 问题描述 定义: 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则 ...

  9. 动态规划求最长公共子序列(Longest Common Subsequence, LCS)

    1. 问题描述 子串应该比较好理解,至于什么是子序列,这里给出一个例子:有两个母串 cnblogs belong 比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与 ...

随机推荐

  1. wp手机 htc x310e

    入手htc x310e 手机不错,用着流畅 不习惯,已升到wp7.8,系统限制还是有些需要的功能没有,比如说短信拦截什么的 我需要的常用软件少 转手了 1 注销windows live? 设置--应用 ...

  2. iOS开发——UI基础-KVC

    除了一般的赋值和取值的方法,我们还可以用Key-Value-Coding(KVC)键值编码来访问你要存取的类的属性. 如何使用KVC存取对象属性呢?看个示例 一.使用KVC存数据 定义一个person ...

  3. python 深入模块和包

    模块可以包含可执行语句以及函数的定义. 这些语句通常用于初始化模块. 它们只在 第一次 导入时执行.只在第一次导入的时候执行,第一次.妈蛋的第一次...后面再次导入就不执行了. [1](如果文件以脚本 ...

  4. JS中try....catch

    1.事情还有得挽回,换条路走try { 执行某个逻辑} catch (e) { 出问题,换个逻辑执行} 2.体面的退出try { 正常流程} catch (e) { 弹个框告诉用户不好意思出了点问题 ...

  5. jQuery lazyload插件详解和问题解答

    lazyload插件用于图片延迟加载,节省服务器带宽,减少服务器请求次数,提高网站的页面加载速度,用于网站性能优化,只有当图片在窗口可视范围内时才向服务器请求: 参数: threshold:设置距离窗 ...

  6. 百度网盘爬虫Python

    ": for i in range((shares["total_count"]-1)/ONESHAREPAGE): try: dbcurr.execute('INSER ...

  7. django的跨站请求访问

    一.简介 django为用户实现防止跨站请求伪造的功能,通过中间件 django.middleware.csrf.CsrfViewMiddleware 来完成.而对于django中设置防跨站请求伪造功 ...

  8. MFCC可视化

    大多数文章和博客介绍都是MFCC的算法流程,物理意义,这里仅仅从数据分布可视化的角度,清晰 观察MFCC特征在空间中的分布情况,加深理解. MFCC处理流程: MFCC参数的提取包括以下几个步骤: 1 ...

  9. 第七天 面向对象进阶与socket编程

    1.静态方法(用得少)(解除某个函数跟类的关联,加了静态方法后,类便不能将类的参数传给静态方法函数了) class Dog(object): def __init__(self,name): @sta ...

  10. linux skill

    linux console终端乱码解决 1.console终端乱码 在/etc/profile文件的最后一行添加如下内容: export LC_ALL="zh_CN.GB18030" ...