leetCode算法—4.寻找两个正序数组的中位数

1.给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。

算法的时间复杂度应该为 O(log (m+n)) 。

示例 1:

输入:nums1 = [1,3], nums2 = [2]

输出:2.00000

解释:合并数组 = [1,2,3] ,中位数 2

示例 2:

输入:nums1 = [1,2], nums2 = [3,4]

输出:2.50000

解释:合并数组 = [1,2,3,4] ,中位数 (2 + 3) / 2 = 2.5

提示:

nums1.length == m

nums2.length == n

0 <= m <= 1000

0 <= n <= 1000

1 <= m + n <= 2000

-106 <= nums1[i], nums2[i] <= 106

2.解法

复制代码
export const findMedianSortedArrays = function (nums1, nums2) {
    //保证nums1长度小于nums2,因为他们的分隔线位置互相影响
    if (nums1.length > nums2.length) {
        [nums1, nums2] = [nums2, nums1];
    }
    //取长度
    let m = nums1.length, n = nums2.length;
    //在0~m区域
    let left = 0, right = m;
    //暂存左半段的最大值,右半段的最小值
    let median1 = 0, median2 = 0;

    while (left <= right) {
        //找nums1这里的中位线作为分隔线
        const i = left + Math.floor((right - left) / 2);
        //想象两个数组合并成一个新数组的总长度取中位线 - 左半段的分隔线,就是右半段分隔线的初始位置
        const j = Math.floor((m + n + 1) / 2) - i;
        //判断特殊情况,比如num1的中位线就是在下标0处,那么这分隔线也就缺乏意义了。
        const maxLeft1 = i === 0 ? -Infinity : nums1[i - 1];
        const minRight1 = i === m ? Infinity : nums1[i];
        const maxLeft2 = j === 0 ? -Infinity : nums2[j - 1];
        const minRight2 = j === n ? Infinity : nums2[j];
        console.log({ i, j, maxLeft1, minRight1, maxLeft2, minRight2 })

        //不停通过二分查找调整分隔线的位置,直到找到对应的数组,然后取中间值
        if (maxLeft1 <= minRight2) {
            median1 = Math.max(maxLeft1, maxLeft2);
            median2 = Math.min(minRight1, minRight2);
            left = i + 1;
        } else {
            right = i - 1;
        }
        console.log({ median1, median2 })
    }
    return (m + n) % 2 == 0 ? (median1 + median2) / 2 : median1;
};

欢迎大家给出更好的解法!!!

上一篇:leetCode算法---3.无重复字符的最长子串

下一篇:

相关推荐
Tisfy1 分钟前
LeetCode 960.删列造序 III:动态规划(最长递增子序列)
算法·leetcode·动态规划·字符串·题解·逆向思维
多米Domi0113 分钟前
0x3f第十天复习(考研日2)(9.18-12.30,14.00-15.00)
python·算法·leetcode
listhi5207 分钟前
支持向量机多分类解决方案
算法·支持向量机·分类
十三画者8 分钟前
【文献分享】vConTACT3机器学习能够实现可扩展且系统的病毒分类体系的构建
人工智能·算法·机器学习·数据挖掘·数据分析
TrueFurina(互关互赞)21 分钟前
7-4 区间水仙花数 Python程序设计-MJU实验四(编程入门•多代码实现•测试均通过)
数据结构·算法·飞书·创业创新·学习方法·远程工作·改行学it
Amnesia0_021 分钟前
Map和Set
算法
受伤的僵尸23 分钟前
算法类复习(1)-非自注意力机制(图像处理中的注意力)
人工智能·算法
_w_z_j_25 分钟前
最小高度树
算法
2301_7890156229 分钟前
每日精讲:环形链表、两个数组中的交集、随机链表的复制
c语言·数据结构·c++·算法·leetcode·链表·排序算法
CodeByV32 分钟前
【算法题】滑动窗口 (二)
算法