51nod 1006:最长公共子序列Lcs
2015-09-10 10:51
447 查看
1006 最长公共子序列Lcs
基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题
收藏
关注
给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的)。
比如两个串为:
abcicba abdkscab
ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符串最长的子序列。
Input
Output
Input示例
Output示例
代码:
基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题
收藏
关注
给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的)。
比如两个串为:
abcicba abdkscab
ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符串最长的子序列。
Input
第1行:字符串A 第2行:字符串B (A,B的长度 <= 1000)
Output
输出最长的子序列,如果有多个,随意输出1个。
Input示例
abcicba abdkscab
Output示例
abca
代码:
#include <iostream> #include <algorithm> #include <cmath> #include <vector> #include <string> #include <cstring> #pragma warning(disable:4996) using namespace std; char a[1005]; char b[1005]; int dp[1005][1005]; int pre[1005][1005]; void dfs(int m,int n) { if(m==0||n==0) return; if(pre[m] ==1) { dfs(m-1,n-1); cout<<a[m]; } else if(pre[m] ==2) { dfs(m-1,n); } else { dfs(m,n-1); } } int main() { int i,j,len1,len2; memset(dp,0,sizeof(dp)); memset(pre,0,sizeof(pre)); cin>>a+1>>b+1; len1=strlen(a+1); len2=strlen(b+1); for(i=1;i<=len1;i++) { for(j=1;j<=len2;j++) { if(a[i]==b[j]) { dp[i][j]=dp[i-1][j-1]+1; pre[i][j]=1; } else { if(dp[i-1][j]>dp[i][j-1]) { dp[i][j]=dp[i-1][j]; pre[i][j]=2; } else { dp[i][j]=dp[i][j-1]; pre[i][j]=3; } } } } dfs(len1,len2); cout<<endl; return 0; }
相关文章推荐
- struct和typedef struct彻底明白了
- JSON和JSONP有哪些区别,PhoneGap跨域请求如何实现,什么是JSON,JSON的优点, JSON的格式或者叫规则。
- KMP算法详解
- Redis - 01. 安装及测试
- Linux管理常用命令
- mybatis学习教程中级(八)延迟加载
- JS的Document属性和方法
- Java中equals和==的区别
- 新手必备的27个常用命令
- LeetCode_valid-anagram
- ecshop中{insert name='history'}修改方法
- ios-裁剪加裁剪描边加把裁剪封装成一个方法类
- CSS强制性换行
- VIM命令学习
- Linux下rz/sz安装及使用方法
- Android国际化
- 数据备份及恢复
- Cortex-M3的存储器映射
- 2015、9、10 已忘初心
- ABAP选择屏幕(SELECTION SCREEN)事件解析