博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LCS变形--hdu1503
阅读量:5253 次
发布时间:2019-06-14

本文共 1541 字,大约阅读时间需要 5 分钟。

题目其实很简单,就是你找到两个字符串的最大公共子序列,然后把两个字符串都输入,但是最大公共子序列只输出一次

这道题初看其实很难理解,搞明白了之后我画了一张图,有了它这道题小学生都能做出来啦!

 

 

比方说你已经找到了图中的黑线连接的关系(最大公共子序列),那么已按照图中的圆圈圈起来的顺序输出这些字符就好啦~

思路清楚之后,核心还是LCS算法,多了一点就是要储存LCS,如何储存呢?不用我多讲,请看代码:

#include 
#include
#define INF 0x3f3f3f3fusing namespace std;const int maxn=0x3f3f3f3f;char a[110],b[100]; int dp[110][110];int la,lb;int len;struct node{ int ba; int bb; char c;}ans[110];void lcs(){ for(int i=1;i<=la;i++){ for(int j=1;j<=lb;j++){ if(a[i]==b[j]){ dp[i][j]=dp[i-1][j-1]+1; } else{ dp[i][j]=max(dp[i][j-1],dp[i-1][j]); } } } if(!dp[la][lb]) printf("%s%s",a,b); else{ int i=la; int j=lb; len=1; while(i!=0 && j!=0){ if(a[i]==b[j] && (dp[i][j]==dp[i-1][j-1]+1)){ ans[len].ba=i; ans[len].bb=j; ans[len++].c=a[i]; i--; j--; } else if(dp[i][j-1]>dp[i-1][j]){ j--; } else{ i--; } } }}int main(){// freopen("in.txt","r",stdin); while( scanf("%s%s",a+1,b+1) ){ memset(dp,0,sizeof(dp)); if(a[1]=='0') break; la=strlen(a+1); lb=strlen(b+1); lcs(); int i=1; int j=1; for(int k=len-1;k>0;k--){ while(i < ans[k].ba){ cout<
View Code

 

转载于:https://www.cnblogs.com/ucandoit/p/8810763.html

你可能感兴趣的文章
CodeForces Round #545 Div.2
查看>>
卷积中的参数
查看>>
51nod1076 (边双连通)
查看>>
Item 9: Avoid Conversion Operators in Your APIs(Effective C#)
查看>>
深入浅出JavaScript(2)—ECMAScript
查看>>
STEP2——《数据分析:企业的贤内助》重点摘要笔记(六)——数据描述
查看>>
ViewPager的onPageChangeListener里面的一些方法参数:
查看>>
Jenkins关闭、重启,Jenkins服务的启动、停止方法。
查看>>
CF E2 - Array and Segments (Hard version) (线段树)
查看>>
Linux SPI总线和设备驱动架构之四:SPI数据传输的队列化
查看>>
SIGPIPE并产生一个信号处理
查看>>
CentOS
查看>>
Linux pipe函数
查看>>
java equals 小记
查看>>
爬虫-通用代码框架
查看>>
2019春 软件工程实践 助教总结
查看>>
YUV 格式的视频呈现
查看>>
Android弹出框的学习
查看>>
现代程序设计 作业1
查看>>
在android开发中添加外挂字体
查看>>