题目描述:
代码如下:动态规划
class Solution {
public int longestCommonSubsequence(String text1, String text2) {
int m=text1.length();
int n=text2.length();
int dp[][]=new int[m+1][n+1];
ini(dp,m,n);//初始化dp
//dp[i][j]相当于长度为i的text1与长度为j的text2 的最长公共子序列
for(int i=1;i<=m;i++){
for(int j=1;j<=n;j++){
//状态转移条件
if(text1.charAt(i-1)==text2.charAt(j-1)){
dp[i][j]=dp[i-1][j-1]+1;
}else{
dp[i][j]=Math.max(dp[i-1][j],dp[i][j-1]);
}
}
}
return dp[m][n];
}
public void ini(int [][]dp,int m,int n){
for(int i=0;i<m;i++){
dp[i][0]=0;
}
for(int j=0;j<n;j++){
dp[0][j]=0;
}
}
}
递归备忘录写法:
class Solution {
int table[][];
public int longestCommonSubsequence(String text1, String text2) {
int m=text1.length();
int n=text2.length();
table=new int[m][n];
ini(table);
return dp(text1,text2,m-1,n-1);
}
int dp(String t1,String t2,int m,int n){
if(m==-1||n==-1){//字符串是空串
return 0;
}
if(table[m][n]!=-1){//备忘录不为空
return table[m][n];
}
int res=Integer.MIN_VALUE;
if(t1.charAt(m)==t2.charAt(n)){
res=dp(t1,t2,m-1,n-1)+1;//当两个字符相等的时候,公共子序列长度+1
}else{
res=Math.max(dp(t1,t2,m,n-1),dp(t1,t2,m-1,n));//不相等的时候,选更长的一边
}
table[m][n]=res;
return res;
}
void ini(int arr[][]){//初始化备忘录
for(int i=0;i<arr.length; i++){
for(int j=0;j<arr[i].length;j++){
table[i][j]=-1;
}
}
}
}