其他分享
首页 > 其他分享> > 1143. Longest Common Subsequence

1143. Longest Common Subsequence

作者:互联网

问题:

给定两个字符串,求他们的最长公共子序列的长度。

Example 1:
Input: text1 = "abcde", text2 = "ace" 
Output: 3  
Explanation: The longest common subsequence is "ace" and its length is 3.

Example 2:
Input: text1 = "abc", text2 = "abc"
Output: 3
Explanation: The longest common subsequence is "abc" and its length is 3.

Example 3:
Input: text1 = "abc", text2 = "def"
Output: 0
Explanation: There is no such common subsequence, so the result is 0.
 
Constraints:
1 <= text1.length <= 1000
1 <= text2.length <= 1000
The input strings consist of lowercase English characters only.

  

解法:DP(动态规划)

1.确定【状态】:

2.确定【选择】:分两种情况

3. dp[i][j]的含义:

对比到text1的第 i 个字符,text2的第 j 个字符为止,两个字符串的最大公共子序列长度。

4. 状态转移:

dp[i][j]=

5. base case:

代码参考:

 1 class Solution {
 2 public:
 3     //dp[i][j]:until text1[i],text2[j]. the max length of the LCS
 4     //case_1: text1[i]==text2[j]:
 5     //        this character must be in LCS. we need add 1 to pre status:dp[i-1][j-1].
 6     //        =dp[i-1][j-1]+1
 7     //case_2: text1[i]!=text2[j]
 8     //        text1[i] or text2[j] may in LCS. we choose the max of these possibilities.
 9     //        if text1[i] is in LCS, 
10     //        = dp[i][j-1]
11     //        if text2[j] is in LCS, 
12     //        = dp[i-1][j]
13     //        if none of them is in LCS, 
14     //        = dp[i-1][j-1]
15     // note: dp[i-1][j-1]<=dp[i-1][j](dp[i][j-1]) ,so we can ignore it
16     //        =max(dp[i][j-1],dp[i-1][j])
17     //base case:
18     //dp[i][0]=0
19     //dp[0][j]=0
20     int longestCommonSubsequence(string text1, string text2) {
21         int m = text1.length(), n = text2.length();
22         vector<vector<int>> dp(m+1, vector<int>(n+1, 0));
23         for(int i=1; i<=m; i++) {
24             for(int j=1; j<=n; j++) {
25                 if(text1[i-1]==text2[j-1]) {
26                     dp[i][j]=dp[i-1][j-1]+1;
27                 } else {
28                     dp[i][j]=max(dp[i-1][j], dp[i][j-1]);
29                 }
30             }
31         }
32         return dp[m][n];
33     }
34 };

♻️ 优化:

空间复杂度:2维->1维

去掉 i 

压缩所有行到一行。

左上角dp[i-1][j-1]会被下面的dp[i][j-1]覆盖,因此引入变量pre,在更新dp[i][j-1]之前,保存dp[i-1][j-1]

代码参考:

 1 class Solution {
 2 public:
 3     int longestCommonSubsequence(string text1, string text2) {
 4         int m = text1.length(), n = text2.length();
 5         vector<int> dp(n+1, 0);
 6         for(int i=1; i<=m; i++) {
 7             int pre = 0;
 8             for(int j=1; j<=n; j++) {
 9                 int tmp = dp[j];
10                 if(text1[i-1]==text2[j-1]) {
11                     dp[j]=pre+1;
12                 } else {
13                     dp[j]=max(dp[j], dp[j-1]);
14                 }
15                 pre = tmp;
16             }
17         }
18         return dp[n];
19     }
20 };

 

标签:1143,LCS,字符,text2,Subsequence,text1,Longest,序列,dp
来源: https://www.cnblogs.com/habibah-chang/p/13621859.html