1 题目描述
2 解题思路
k条互不相交的直线分别连接了数组 nums1和nums2的 k 对相等的元素,而且这 k 对相等的元素在两个数组中的相对顺序是一致的,因此,这 k 对相等的元素组成的序列即为数组 nums1和nums2的公共子序列。要计算可以绘制的最大连线数,即为计算数组nums1和nums2的最长公共子序列的长度。
最长公共子序列长度的求解方法见“文巾解题1738. 找出第 K 大的异或坐标值”(https://blog.csdn.net/qq_40206371/article/details/117037314)
class Solution:
def maxUncrossedLines(self, nums1: List[int], nums2: List[int]) -> int:
ret=[]
for i in range(len(nums1)+1):
ret.append([0]*(len(nums2)+1))
for i in range(1,len(nums1)+1):
for j in range(1,len(nums2)+1):
ret[i][j]=max(ret[i][j-1],
ret[i-1][j],
ret[i-1][j-1]+(nums1[i-1]==nums2[j-1]))
return(max(max(ret)))