博客
关于我
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/

    你可能感兴趣的文章
    PHP请求https域名发生segment fault段错误
    查看>>
    PHP读写XML文件
    查看>>
    PHP读写XML文件
    查看>>
    R&Python Data Science 系列:数据处理(3)
    查看>>
    php读取xml 数据库字段超长处理
    查看>>
    php课程 12-40 抽象类的作用是什么
    查看>>
    php课程 4-16 数组自定义函数(php数组->桶)
    查看>>
    PHP调用接口用post方法传送json数据
    查看>>
    php转化IP为整形
    查看>>
    php输出数据到csv文件
    查看>>
    php输出语句
    查看>>
    php运行原理详细说明
    查看>>
    php运行环境出现Undefined index 或variable时解决方法
    查看>>
    php进程通信
    查看>>
    R&Python Data Science 系列:数据处理(2)
    查看>>
    php递归算法总结
    查看>>
    PHP递归遍历文件夹
    查看>>
    R&Python Data Science 系列:数据处理(1)
    查看>>
    php错误日志文件
    查看>>
    PHP错误解决:Array and string offset access syntax with curly braces is deprecated
    查看>>