博客
关于我
文巾解题 1035. 不相交的线
阅读量:793 次
发布时间:2019-03-24

本文共 1183 字,大约阅读时间需要 3 分钟。

题目描述题目要求找到两个数组的最长公共子序列的长度。给定的两个数组nums1和nums2中,分别有k对相等的元素,这些元素的顺序在两个数组中保持一致。我们的目标是找到这些相等元素组成的最长序列长度。

解题思路要解决这个问题,我们可以利用动态规划(DP)的技术原则来找出两个数组的公共子序列的最大长度。具体来说,我们会建立一个二维数组dp,其中dp[i][j]表示处理数组nums1的前i个元素和数组nums2的前j个元素时,能够找到的最大公共子序列的长度。

我们可以通过以下步骤来计算dp数组中每个位置的值:

  • 如果nums1的当前元素等于nums2的当前元素,那么dp[i][j] = dp[i-1][j-1] + 1,因为我们找到了一个新的公共元素。
  • 如果nums1的当前元素大于nums2的当前元素,那么dp[i][j] = dp[i-1][j],因为我们无法通过当前的nums2[i-1]来匹配。
  • 如果nums2的当前元素大于nums1的当前元素,那么dp[i][j] = dp[i][j-1],因为我们无法通过当前的nums1[i-1]来匹配。
  • 最终,dp数组的右下角的值dp[len(nums1)][len(nums2)]将给出两个数组的最长公共子序列的长度。

    代码示例

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

    这个代码使用了动态规划的原则来计算两个数组的最长公共子序列长度。我们初始化一个_dp表,其中每个元素dp[i][j]记录了当前处理到数组的第i个元素和第j个元素时的最大公共子序列长度。在处理每一个元素时,我们根据元素是否相等,以及哪个数组的元素更小来决定当前位置的值,由此构建出最终的DP表,并从中提取最大值作为结果。

    转载地址:http://hfvkk.baihongyu.com/

    你可能感兴趣的文章
    multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
    查看>>
    mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
    查看>>
    Multiple websites on single instance of IIS
    查看>>
    mysql CONCAT()函数拼接有NULL
    查看>>
    multiprocessing.Manager 嵌套共享对象不适用于队列
    查看>>
    multiprocessing.pool.map 和带有两个参数的函数
    查看>>
    MYSQL CONCAT函数
    查看>>
    multiprocessing.Pool:map_async 和 imap 有什么区别?
    查看>>
    MySQL Connector/Net 句柄泄露
    查看>>
    multiprocessor(中)
    查看>>
    mysql CPU使用率过高的一次处理经历
    查看>>
    Multisim中555定时器使用技巧
    查看>>
    MySQL CRUD 数据表基础操作实战
    查看>>
    multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
    查看>>
    mysql csv import meets charset
    查看>>
    multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
    查看>>
    MySQL DBA 数据库优化策略
    查看>>
    multi_index_container
    查看>>
    mutiplemap 总结
    查看>>
    MySQL Error Handling in Stored Procedures---转载
    查看>>