1035. 不相交的线

Problem: 1035. 不相交的线

就是 53. 最大子数组和

Code

[]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
class Solution {
public:
int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {
//就是 53. 最大子数组和
//使用二维动态规划
//dp[i][j] 表示text1[0...i]与text2[0...j]的最长公共子序列
int m = nums1.size(), n = nums2.size();
vector<vector<int>> dp(m + 1, vector<int>(n + 1));
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
if (nums1[i-1] == nums2[j-1]) {
//如果相同那么最长公共子序列+1
dp[i][j] = dp[i - 1][j - 1] + 1;
} else {
//如果不同取 两个数组 最长公共子序列最长的那个
dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
}
}
}
return dp[m][n];

}
};