博客
关于我
LeetCode1035—不相交的线(java版)
阅读量:685 次
发布时间:2019-03-17

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

我们可以使用动态规划来解决这个问题。目标是在两条水平线上绘制尽可能多的连接线,前提是连接不相交且数字对应相同。

  • 动态规划定义

    • 定义一个二维数组 dp,其中 dp[i][j] 表示在处理到 A 的前 i 个元素和 B 的前 j 个元素时可以绘制的最大连线数目。
  • 状态转移方程

    • 如果 A[i-1] 等于 B[j-1],则我们可以在此处绘制一条新连线,所以 dp[i][j] = dp[i-1][j-1] + 1
    • 否则,dp[i][j] 取决于上方或左方的值中的最大者,即 dp[i][j] = max(dp[i][j-1], dp[i-1][j])
  • 初始化边界条件

    • dp[0][*]dp[*][0] 初始化为0,因为没有元素时无法绘制连线。
  • 填充动态规划表

    • 遍历 AB 的所有元素,逐步计算每个 dp[i][j] 的值,并更新全局最大值。
  • 通过这个方法,我们可以有效地计算出最大连线数,同时考虑了所有可能的绘制路径,避免了不必要的交叉。

    最终的代码实现如下:

    功能:计算可以绘制的最大连线数输入:两条整数序列A和B输出:最大连线数实现思路:使用动态规划,逐个比较A和B的元素,找出最长非交叉连接的数量。

    题目描述:

    标签:数组

    在两条水平线上按顺序写下整数A和B中的数字。可以绘制连接A[i]和B[j]的线,只要满足A[i]等于B[j]且线不交叉。目标找出最多可绘制的线条数。

    代码:

    class Solution { public int maxUncrossedLines(int[] A, int[] B) { int n1 = A.length; int n2 = B.length; int[][] dp = new int[n1 + 1][n2 + 1]; int result = 0; for (int i = 1; i <= n1; i++) { for (int j = 1; j <= n2; j++) { if (A[i - 1] == B[j - 1]) { dp[i][j] = dp[i-1][j-1] + 1; } else { dp[i][j] = Math.max(dp[i][j-1], dp[i-1][j]); } if (dp[i][j] > result) { result = dp[i][j]; } } } return result; } }

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

    你可能感兴趣的文章
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    nested exception is org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML.
    查看>>
    nestesd exception is java .lang.NoSuchMethodError:com.goolge.common.collect
    查看>>
    nestJS学习
    查看>>
    net core 环境部署的坑
    查看>>
    NET Framework安装失败的麻烦
    查看>>
    Net 应用程序如何在32位操作系统下申请超过2G的内存
    查看>>
    Net.Framework概述
    查看>>
    NET3.0+中使软件发出声音[整理篇]<转>
    查看>>
    net::err_aborted 错误码 404
    查看>>
    NetApp凭借领先的混合云数据与服务把握数字化转型机遇
    查看>>
    Netbeans 8.1启动参数配置
    查看>>
    NetBeans IDE8.0需要JDK1.7及以上版本
    查看>>
    NetBeans之改变难看的JSP脚本标签的背景色...
    查看>>
    netbeans生成的maven工程没有web.xml文件 如何新建
    查看>>
    netcat的端口转发功能的实现
    查看>>
    netfilter应用场景
    查看>>
    netlink2.6.32内核实现源码
    查看>>
    netmiko 自动判断设备类型python_Python netmiko模块的使用
    查看>>