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

    你可能感兴趣的文章
    nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置后台网关映射路径
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置多个不同端口服务共用80端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-动静分离实例:搭建静态资源服务器
    查看>>
    Nginx配置实例-反向代理实例:根据访问的路径跳转到不同端口的服务中
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    nginx配置详解、端口重定向和504
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    Nginx配置限流,技能拉满!
    查看>>
    Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>