博客
关于我
文巾解题 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/

    你可能感兴趣的文章
    Navicat for MySQL(Ubuntu)过期解决方法
    查看>>
    Navicat Premium 12 卸载和注册表的删除
    查看>>
    Navicat 导入sql文件
    查看>>
    navicat 添加外键1215错误
    查看>>
    navicat 系列软件一点击菜单栏就闪退
    查看>>
    navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
    查看>>
    Navicat 设置时间默认值(当前最新时间)
    查看>>
    navicat 连接远程mysql
    查看>>
    navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
    查看>>
    Navicate for mysql 数据库设计-数据库分析
    查看>>
    Navicat下载和破解以及使用
    查看>>
    Navicat中怎样将SQLServer的表复制到MySql中
    查看>>
    navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
    查看>>
    Navicat可视化界面导入SQL文件生成数据库表
    查看>>
    Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
    查看>>
    Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
    查看>>
    Navicat如何连接MySQL
    查看>>
    navicat导入.sql文件出错2006- MySQLserver has gone away
    查看>>
    Navicat导入海量Excel数据到数据库(简易介绍)
    查看>>
    Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
    查看>>