题解 | #最长公共子串#
最长公共子串
http://www.nowcoder.com/practice/f33f5adc55f444baa0e0ca87ad8a6aac
两个字符串的最长公共子串和最长公共子序列
最长公共子串
最长公共子序列
//最长公共子串
public class Solution {
public String LCS (String str1, String str2) {
int m=str1.length();
int n=str2.length();
int[][] dp=new int[m+1][n+1];
int tail_index=0;
int maxlen=0;
for(int i=1;i<=m;i++){
for(int j=1;j<=n;j++){
if(str1.charAt(i-1)==str2.charAt(j-1)){
dp[i][j]=dp[i-1][j-1]+1;
}
if(dp[i][j]>maxlen){
maxlen=dp[i][j];
tail_index=i;
}
}
}
return str1.substring(tail_index-maxlen,tail_index);
}
}//最长公共子序列
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];
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];
}
}
