求公共最長子序列數目,這種類型不用多想,dp就完了(自我感受最簡單的dp)ios
首先肯定狀態,兩串字符串比較,因此用二維的dp[i][j]spa
而後轉移方程,當str1[i]=str2[j]時,由兩字符串同時加一獲得,dp[i][j]=dp[i-1][j-1]+1;ci
當str1[i]!=str2[j]時,dp[i][j]=max(dp[i-1][j],dp[i][j-1]);字符串
固然須要定義邊界條件,好比:i=0或j=0時,dp[0][j]或dp[i][0]=0;string
按從小到大的順序遍歷就完了,時間複雜度O(n^2);io
而後若是要輸出最長公共子序列的時候就倒退,原理懂了很簡單(這部分代碼註釋是掉的)stream
下面是代碼:原理
#include <iostream>
#include <string>
#include <vector>
using namespace std;遍歷
int main()
{
string str1,str2;
while(cin>>str1>>str2){
//cin >> str1 >> str2;
int x1=str1.size(),x2=str2.size(),i,j;
vector<int>vec(x1+1,0);
vector<vector<int> > vec1(x2+1,vec);
for(i=0;i<x2;i++){//str2
for(j=0;j<x1;j++){//str1
if(str1[j]==str2[i])vec1[i+1][j+1]=vec1[i][j]+1;
else if(vec1[i+1][j]>vec1[i][j+1])vec1[i+1][j+1]=vec1[i+1][j];
else vec1[i+1][j+1]=vec1[i][j+1];
}
}
cout << vec1[i][j] << endl;
/*
int k=0;
while(i>0&&j>0)
if(vec1[i][j]==vec1[i-1][j])i--;
else if(vec1[i][j]==vec1[i][j-1])j--;
else{
i--,j--;
vec[k++]=j;
}
for(i=k-1;i>=0;i--){
cout << str1[vec[i]];
}
cout << endl;
*/
}
return 0;
}註釋