首页 > 其他 > 详细

最长公共子序列的代码实现

时间:2017-02-13 23:58:57      阅读:466      评论:0      收藏:0      [点我收藏+]

关于最长公共子序列(LCS)的相关知识,http://blog.csdn.net/liufeng_king/article/details/8500084 这篇文章讲的比较好,在此暂时不再详说。

以下是我代码实现两种方式:递归+递推:

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 int A[100];
 4 int B[100];
 5 
 6 //int B[]={2,3,5,6,9,8,4};
 7 int d[100][100]={0};
 8 int dp(int i, int j,vector<int> &vs){
 9     int &ans = d[i][j];
10     if(ans > 0)return ans;
11     if(i>0&&j>0){
12         if(A[i] == B[j]){
13             ans = dp(i-1,j-1)+1;
14         } 
15         else ans = max(dp(i-1,j),dp(i,j-1));
16     }
17     else{
18         ans  = 0;
19     }
20     return ans;
21 }
22 int LCS(int n1, int n2){
23     for(int i = 0; i <= n1; i++)d[i][0] = 0;
24     for(int i = 0; i <= n2; i++)d[0][i] = 0;    
25     for(int i = 1; i<= n1; i++){
26         for(int j = 1; j<= n2; j++){
27             if(A[i]==B[j]){
28                 d[i][j] = d[i-1][j-1]+1;
29             }
30             else d[i][j] = max(d[i-1][j], d[i][j-1]);
31         }
32     }
33     return d[n1][n2];
34 }
35 int main(){
36     int n1,n2 ;
37     cin >> n1;
38     for(int i = 1;i <= n1; i++) cin >> A[i];
39     cin >> n2;
40     for(int i = 1;i <= n2; i++) cin >> B[i];
41     memset(d,-1,sizeof(d));
42     d[0][0] = 0;
43     vector<int> vs;
44     cout << dp(n1,n2,vs) << endl;
45     cout << LCS(n1 ,n2) << endl;
46     //cout << dp(5,6) << endl;
47 
48     return 0;
49 }

 

最长公共子序列的代码实现

原文:http://www.cnblogs.com/Wade-/p/6392913.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!