博客
关于我
这道算法题太简单?你忽略了时间复杂度的要求!
阅读量:678 次
发布时间:2019-03-16

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

LeetCode 4. 寻找两个有序数组的中位数

题目大意是给定两个有序数组 nums1 和 nums2,要求找到它们合并后的中位数,并且要保证算法的时间复杂度为 O(log(m + n)),其中 m 和 n 分别是两个数组的长度。


题目解析

中位数是两个数组合并后按照大小顺序排列后的中间值。对于偶数个元素的情况,中位数是中间两个数的平均值。对于奇数个元素,则是中间的那个数。

常规的解法是将两个数组合并后进行排序,然后找到中间的元素。然而,这种方法的时间复杂度为 O(m + n),无法满足题目要求的 O(log(m + n)) 高效率。


动作描述

我们需要通过二分查找的方法来找到两个有序数组中的中位数。具体思路如下:

  • 确定中位数的位置

    首先,计算两个数组的总长度的中位数位置 k。

    • 如果数组总长度为奇数,k 是中间的那个位置。
    • 如果总长度为偶数,k 会取中间两个位置的平均值的位置。
  • 在两个数组中同时查找第 k 小的元素

    我們需要同时在 nums1 和 nums2 中查找第 k 小的元素。

    • 比较两个数组中当前位置的元素,决定继续查找的方向。
    • 每次查找缩小范围,因此时间复杂度为 O(log(m + n))。
  • 计算中位数

    然后将两个数组中第 k 小的元素相加,取平均值即可得到中位数。


  • 代碼實現

    public double findMedianSortedArrays(int[] nums1, int[] nums2) {    int n = nums1.length;    int m = nums2.length;    int left = (n + m + 1) / 2;    int right = (n + m + 2) / 2;    int k1 = getKth(nums1, 0, n - 1, nums2, 0, m - 1, left);    int k2 = getKth(nums1, 0, n - 1, nums2, 0, m - 1, right);    return (k1 + k2) * 0.5;}private int getKth(int[] nums1, int start1, int end1, int[] nums2,                   int start2, int end2, int k) {    int len1 = end1 - start1 + 1;    int len2 = end2 - start2 + 1;    if (len1 > len2) {        return getKth(nums2, start2, end2, nums1, start1, end1, k);    }    if (len1 == 0) {        return nums2[start2 + k - 1];    }    if (k == 1) {        return Math.min(nums1[start1], nums2[start2]);    }    int i = start1 + (Math.min(len1, k / 2) - 1);    int j = start2 + (Math.min(len2, k / 2) - 1);    if (nums1[i] > nums2[j]) {        return getKth(nums1, start1, end1, nums2, j + 1, end2, k - (j - start2 + 1));    } else {        return getKth(nums1, i + 1, end1, nums2, start2, end2, k - (i - start1 + 1));    }}

    了容分析

    • 时间複雜度:每次查找都将查找范围缩小一半,因此整体复雜度为 O(log(m + n))。
    • 空間複雜度:使用了递归,但尾蹓尾噬ợi壽命小,因此空間複雜度是 O(1)。

    参考內容

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

    你可能感兴趣的文章
    OSI七层模型与TCP/IP四层与五层模型详解
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>
    OSPF 四种设备角色:IR、ABR、BR、ASBR
    查看>>
    OSPF 学习
    查看>>
    OSPF 概念型问题
    查看>>
    SQL Server 存储过程分页。
    查看>>
    OSPF不能发现其他区域路由时,该怎么办?
    查看>>
    OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
    查看>>
    SQL Server 存储过程
    查看>>
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>
    OSPF技术入门(第三十四课)
    查看>>
    OSPF技术连载10:OSPF 缺省路由
    查看>>
    OSPF技术连载11:OSPF 8种 LSA 类型,6000字总结!
    查看>>
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载14:OSPF路由器唯一标识符——Router ID
    查看>>
    OSPF技术连载15:OSPF 数据包的类型、格式和邻居发现的过程
    查看>>
    OSPF技术连载16:DR和BDR选举机制,一篇文章搞定!
    查看>>
    OSPF技术连载17:优化OSPF网络性能利器——被动接口!
    查看>>
    OSPF技术连载18:OSPF网络类型:非广播、广播、点对多点、点对多点非广播、点对点
    查看>>