day57 动态规划part14 代码随想录算法训练营 1035. 不相交的线
题目:1035. 不相交的线
我的感悟:
- 换汤不换药
理解难点:
- 换了个壳子
听课笔记:
- 多理解这个题意
我的代码:
class Solution:
def maxUncrossedLines(self, nums1: List[int], nums2: List[int]) -> int:
# 因为强调顺序,所以跟1143最长公共子序列是一样的
dp = [[0] * (len(nums1)+1) for _ in range(len(nums2)+1)]
# nums1 内 nums2 外
for i in range(1,len(nums2)+1):
for j in range(1,len(nums1)+1):
if nums1[j-1] == nums2[i-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[-1][-1]
通过截图:
代码易错点:
老师代码:
扩展写法:
资料:
1035.不相交的线
其实本题和 1143.最长公共子序列 是一模一样的,大家尝试自己做一做。
视频讲解:https://www.bilibili.com/video/BV1h84y1x7MP
https://programmercarl.com/1035.%E4%B8%8D%E7%9B%B8%E4%BA%A4%E7%9A%84%E7%BA%BF.html