蓝桥杯 算法提高 最长公共子序列
2017-10-16 00:09
176 查看
算法提高 最长公共子序列
时间限制:1.0s 内存限制:256.0MB
问题描述
给定两个字符串,寻找这两个字串之间的最长公共子序列。
输入格式
输入两行,分别包含一个字符串,仅含有小写字母。
输出格式
最长公共子序列的长度。
样例输入
abcdgh
aedfhb
样例输出
3
样例说明
最长公共子序列为a,d,h。
数据规模和约定
字串长度1~1000。
时间限制:1.0s 内存限制:256.0MB
问题描述
给定两个字符串,寻找这两个字串之间的最长公共子序列。
输入格式
输入两行,分别包含一个字符串,仅含有小写字母。
输出格式
最长公共子序列的长度。
样例输入
abcdgh
aedfhb
样例输出
3
样例说明
最长公共子序列为a,d,h。
数据规模和约定
字串长度1~1000。
#include<iostream> #include<string> using namespace std; int dp[1001][1001]; // 类似于打表。 int main() { string x,y; cin >>x>>y; int xlen=x.length(),ylen=y.length(),i,j; for(i=1;i<=xlen;i++){ for(j=1;j<=ylen;j++) { if(x[i-1]==y[j-1]) dp[i][j]=dp[i-1][j-1]+1; else if(dp[i-1][j]>dp[i][j-1]) dp[i][j]=dp[i-1][j]; else dp[i][j]=dp[i][j-1]; } } /* for(i=0;i<=xlen;i++){ for(j=0;j<=ylen;j++){ cout <<dp[i][j]<<" " ; } cout <<endl; } */ cout <<dp[i-1][j-1]<<endl; //输出lcs长度 /* char lcs[1001]; int k=0; while(xlen&&ylen){ if(x[xlen-1]==y[ylen-1]&&dp[xlen][ylen]==dp[xlen-1][ylen-1]+1){ lcs[k++]=x[xlen-1]; xlen--; ylen--; } else if(x[xlen-1]!=y[ylen-1]&&dp[xlen-1][ylen]>dp[xlen][ylen-1]) xlen--; else ylen--; } for(i=k-1;i>=0;i--) cout <<lcs[i]; //输出最长公共子序列。 */ return 0; }
相关文章推荐
- 蓝桥杯 ADV-202算法提高 最长公共子序列(动态规划)
- 蓝桥杯算法提高身份证号码升级
- 蓝桥杯 ADV-178 算法提高 简单加法
- 蓝桥杯算法提高 排列数
- 蓝桥杯 算法提高 日期计算(Java解题)
- 蓝桥杯-算法提高-Cowboys
- 蓝桥杯练习: 算法提高 9-2 文本加密
- 蓝桥杯 算法提高 周期字串
- 蓝桥杯 算法提高VIP 聪明的美食家(Java解题)
- 蓝桥杯-算法提高-任意年月日历输出
- 蓝桥杯训练:算法提高 高精度加法
- 蓝桥杯 算法提高 扶老奶奶过街
- 蓝桥杯 算法提高 夺宝奇兵
- 蓝桥杯 贪心模板 _算法提高 快乐司机
- 算法提高 矩阵乘法 蓝桥杯
- 蓝桥杯 算法提高 上帝造题五分钟(Java解题)
- C++ - 蓝桥杯 - 算法提高 学霸的迷宫 (bfs+记录路径)
- 蓝桥杯 算法提高 分苹果 【差分数组 + 离线区间加 + 板子题】
- 蓝桥杯 算法提高 最大乘积 【贪心】
- 算法-蓝桥杯-算法提高 P1001(JAVA)