1143. Longest Common Subsequence
Last updated
Last updated
/**
* Time complexity :
* Space complexity :
*/
class Solution {
public int longestCommonSubsequence(String text1, String text2) {
if(text1 == null || text2 == null || text1.isEmpty() || text2.isEmpty()) {
return 0;
}
int t1Len = text1.length(), t2Len = text2.length();
int[][] dp = new int[t1Len+1][t2Len+1];
for(int i = 1; i <= t1Len; i++) {
for(int j = 1; j <= t2Len; j++) {
if(text1.charAt(i-1) == text2.charAt(j-1)) {
dp[i][j] = 1 + dp[i-1][j-1];
} else {
dp[i][j] = Math.max(dp[i-1][j], dp[i][j-1]);
}
}
}
return dp[t1Len][t2Len];
}
}