不相交的线
力扣 1035. 不相交的线
题目说明
在两条独立的水平线上按给定的顺序写下
nums1和nums2中的整数。现在,可以绘制一些连接两个数字
nums1[i]和nums2[j]的直线,这些直线需要同时满足满足:-
nums1[i] == nums2[j] - 且绘制的直线不与任何其他连线(非水平线)相交。
请注意,连线即使在端点也不能相交:每个数字只能属于一条连线。
以这种方法绘制线条,并返回可以绘制的最大连线数。
-
提示:
1 <= nums1.length <= 5001 <= nums2.length <= 5001 <= nums1[i], nums2[i] <= 2000
示例
示例 1:
1 | 输入:nums1 = [1,4,2], nums2 = [1,2,4] |
示例 2:
1 | 输入:nums1 = [2,5,1,2,5], nums2 = [10,5,2,1,5,2] |
示例 3:
1 | 输入:nums1 = [1,3,7,1,7,5], nums2 = [1,9,2,5,1] |
笔者理解
此题是一道数组算法问题,在力扣题库中被定义为中等题。
解法
当笔者阅读完此题后,发现此题需要用到动态规划,此题中的状态转移方程不难想出,让我们来看看具体如何实现的吧。
实现
1 | public int maxUncrossedLines(int[] nums1, int[] nums2) { |
时间和空间效率都还行,可见此解法还比较适合此题;
总结
本题是今天的每日一题,难度是为中等,感兴趣的朋友都可以去尝试一下,此题还有其他更多的解法,朋友们可以自己逐一尝试。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 徐年の博客!









