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

    你可能感兴趣的文章
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty的网络框架差点让我一夜秃头,哭了
    查看>>
    Netty相关
    查看>>
    Netty简介
    查看>>
    Netty线程模型理解
    查看>>
    netty解决tcp粘包和拆包问题
    查看>>
    Netty速成:基础+入门+中级+高级+源码架构+行业应用
    查看>>
    Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
    查看>>
    netty(1):NIO 基础之三大组件和ByteBuffer
    查看>>
    Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
    查看>>
    Netty:原理架构解析
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    Network 灰鸽宝典【目录】
    查看>>
    Networkx写入Shape文件
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    network小学习
    查看>>
    Netwox网络工具使用详解
    查看>>
    Net与Flex入门
    查看>>