文巾解题 1035. 不相交的线

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)))
        

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UQI-LIUWJ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值