力扣4题:寻找两个正序数组的中位数

【题目描述】

**(困难)**给定两个大小分别为 mn 的正序(从小到大)数组 nums1nums2。请你找出并返回这两个正序数组的 中位数

题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

【解题代码】

java 复制代码
public static double findMedianSortedArrays(int[] nums1, int[] nums2) {
    int len1 = nums1.length;
    int len2 = nums2.length;
    // 采用归并比较算法,因为只需要取中位数,所以新建数组大小nums只需要nums1和nums2一半即可
    int len3 = (len1 + len2) / 2 + 1;
    int[] nums = new int[len3];
    int i1 = 0, i2 = 0, j = 0;
    
   // 采用归并比较算法,向数组nums按大小依次从nums1和nums2拷贝数据
   // 一直到nums1和nums2其中之一遍历完毕,或者新建数组已经塞满
    while (true) {
        if (i1 >= len1 || i2 >= len2 || j >= len3) break;
        if (nums1[i1] < nums2[i2]) {
            nums[j++] = nums1[i1++];
        } else {
            nums[j++] = nums2[i2++];
        }
    }
    
    // 如果新建数组还未塞满,则从未遍历完的数组中直接拷贝数据把新建数组塞满     
    if (j < len3) {
        if (i1 < len1) System.arraycopy(nums1, i1, nums, j, len3 - j);
        if (i2 < len2) System.arraycopy(nums2, i2, nums, j, len3 - j);
    }
    // nums1和nums2之和为偶数,则返回中间两数之和的平均数    
    if (((len1 + len2)) % 2 == 0) 
        return (nums[len3 - 2] + nums[len3 - 1]) / 2.0;
    // nums1和nums2之和为奇数,则直接返回中间数    
    else
        return nums[len3 - 1];
}

【解题步骤】

  1. 拿到题目可知,此算法可以用归并算法进行处理,因为只需要取中位数,所以新建数组大小nums只需要nums1和nums2一半即可 nums2[i2++];

    java 复制代码
     int len1 = nums1.length;
     int len2 = nums2.length;
     // 采用归并比较算法,因为只需要取中位数,所以新建数组大小nums只需要nums1和nums2一半即可
     int len3 = (len1 + len2) / 2 + 1;
     int[] nums = new int[len3];
  2. 采用归并比较算法,向数组nums按大小依次从nums1和nums2拷贝数据,一直到nums1和nums2其中之一遍历完毕,或者新建数组已经塞满

    java 复制代码
    while (true) {
        if (i1 >= len1 || i2 >= len2 || j >= len3) break;
        if (nums1[i1] < nums2[i2]) {
            nums[j++] = nums1[i1++];
        } else {
            nums[j++] = nums2[i2++];
        }
    }
  3. 如果新建数组还未塞满,则从未遍历完的数组中直接拷贝数据把新建数组塞满

    java 复制代码
    if (j < len3) {
        if (i1 < len1) System.arraycopy(nums1, i1, nums, j, len3 - j);
        if (i2 < len2) System.arraycopy(nums2, i2, nums, j, len3 - j);
    }
  4. 根据nums1和nums2之和为奇数还是偶数,返回相应的结果

    java 复制代码
     // nums1和nums2之和为偶数,则返回中间两数之和的平均数
     if (((len1 + len2)) % 2 == 0)
        return (nums[len3 - 2] + nums[len3 - 1]) / 2.0;
    // nums1和nums2之和为奇数,则直接返回中间数
    else
        return nums[len3 - 1];

【思路总结】

  1. 归并算法是数据结构排序算法中一个很重要的算法, 归并排序非常稳定,时间复杂度始终都是 N*logN,另外除了常规的数组排序之外,很多场景都可以应用到,比如笔者以前做过的远程和本地文件夹同步算法,就是两边文件名称数组,进行归并比较处理,大家要掌握这个算法思路以及应用技巧;
  2. 算法应用中,要根据实际情况进行改良,比如在这里因为是取中位数,因此不需要向普通的场景申请两个数组之和的空间,而只需要取一半即可
相关推荐
GIS小天7 分钟前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年7月4日第128弹
人工智能·算法·机器学习·彩票
满分观察网友z25 分钟前
开发者的“右”眼:一个树问题如何拯救我的UI设计(199. 二叉树的右视图)
算法
森焱森2 小时前
无人机三轴稳定化控制(1)____飞机的稳定控制逻辑
c语言·单片机·算法·无人机
循环过三天2 小时前
3-1 PID算法改进(积分部分)
笔记·stm32·单片机·学习·算法·pid
闪电麦坤952 小时前
数据结构:二维数组(2D Arrays)
数据结构·算法
凌肖战2 小时前
力扣网C语言编程题:快慢指针来解决 “寻找重复数”
c语言·算法·leetcode
埃菲尔铁塔_CV算法3 小时前
基于 TOF 图像高频信息恢复 RGB 图像的原理、应用与实现
人工智能·深度学习·数码相机·算法·目标检测·计算机视觉
NAGNIP4 小时前
一文搞懂FlashAttention怎么提升速度的?
人工智能·算法
Codebee4 小时前
OneCode图生代码技术深度解析:从可视化设计到注解驱动实现的全链路架构
css·人工智能·算法