leetcode-寻找两个正序数组的中位数

简介: leetcode-寻找两个正序数组的中位数

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

https://leetcode-cn.com/problems/median-of-two-sorted-arrays/

给定两个大小为 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

示例 3:

输入:nums1 = [0,0], nums2 = [0,0]

输出:0.00000

示例 4:

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

输出:1.00000

示例 5:

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

输出:2.00000

提示:

nums1.length == m

nums2.length == n

0 <= m <= 1000

0 <= n <= 1000

1 <= m + n <= 2000

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

通过次数268,312提交次数691,163

代码有点长,思路很简单;

思路:

1、如果nums1为空,那么只需要查找第二个数组的中位数

2、如果nums2为空,那么只需要查找第一个数组的中位数

3、如果都不为空,就合并nums1和nums2,然后对合并后的数组做查找中位数的操作

package 其他.每日一题;
import java.util.Arrays;
class Solution {
    static  public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        if(nums1.length==0)
            return findMidArrays(nums2);
        if(nums2.length==0)
            return findMidArrays(nums1);
        int[] hebing = hebing(nums1, nums2);
//        System.out.println("合并好的数组:"+Arrays.toString(hebing));
        return findMidArrays(hebing);
    }
    //合并数组
    private static int[] hebing(int[] nums1, int[] nums2){
        int len1 = nums1.length;
        int len2 = nums2.length;
        int[] newIntArray = new int[len1+len2];
        int newIndex = 0;
        int i = 0;
        int j = 0;
        while (len1!=0 && len2!=0){
            if(nums1[i]>nums2[j]){
                newIntArray[newIndex]=nums2[j];
                len2--;
                j++;
            }else{
                newIntArray[newIndex]=nums1[i];
                len1--;
                i++;
            }
            newIndex++;
        }
//        System.out.println(Arrays.toString(newIntArray));
        //合并剩余的
        if(len1!=0){
            for (int k = i; k < nums1.length; k++) {
                newIntArray[newIndex]=nums1[k];
                newIndex++;
            }
        }
        if(len2!=0){
            for (int k = j; k < nums2.length; k++) {
                newIntArray[newIndex]=nums2[k];
                newIndex++;
            }
        }
//        System.out.println(Arrays.toString(newIntArray));
        return newIntArray;
    }
    //查找一个单独的数组中的中位数
    private static double findMidArrays(int[] nums) {
        if(nums.length==2){
            return nums[0]+nums[1]==0?0:(nums[0]+nums[1]) / 2.0;
        }
       double midNumber = 0;
//        int number = (nums.length-1)/2;
        int numsLen = nums.length;
        //有偶数个
        if(numsLen%2==0){
            int len = numsLen / 2;
            midNumber = (nums[len] + nums[len-1]) / 2.0;
        //有奇数个
        }else{
            numsLen = (nums.length/2)+1;
            midNumber = nums[numsLen-1];
        }
        return midNumber;
    }
    public static void main(String[] args) {
        System.out.println(findMedianSortedArrays(new int[]{1,2,3,4,5,6},new int[]{}));
        System.out.println(findMedianSortedArrays(new int[]{1,3},new int[]{2}));
    }
}


目录
相关文章
|
4月前
|
Go
【LeetCode 热题100】DP 实战进阶:最长递增子序列、乘积最大子数组、分割等和子集(力扣300 / 152/ 416 )(Go语言版)
本文深入解析三道经典的动态规划问题:**最长递增子序列(LIS)**、**乘积最大子数组** 和 **分割等和子集**。 - **300. LIS** 通过 `dp[i]` 表示以第 `i` 个元素结尾的最长递增子序列长度,支持 O(n²) 动态规划与 O(n log n) 的二分优化。 - **152. 乘积最大子数组** 利用正负数特性,同时维护最大值与最小值的状态转移方程。 - **416. 分割等和子集** 转化为 0-1 背包问题,通过布尔型 DP 实现子集和判断。 总结对比了三题的状态定义与解法技巧,并延伸至相关变种问题,助你掌握动态规划的核心思想与灵活应用!
151 1
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
114 0
LeetCode第53题最大子数组和
LeetCode第53题"最大子数组和"的解题方法,利用动态规划思想,通过一次遍历数组,维护到当前元素为止的最大子数组和,有效避免了复杂度更高的暴力解法。
LeetCode第53题最大子数组和
|
存储 Java API
LeetCode------合并两个有序数组(4)【数组】
这篇文章介绍了LeetCode上的"合并两个有序数组"问题,并提供了三种解法:第一种是使用Java的Arrays.sort()方法直接对合并后的数组进行排序;第二种是使用辅助数组和双指针技术进行合并;第三种则是从后向前的双指针方法,避免了使用额外的辅助数组。
LeetCode------合并两个有序数组(4)【数组】
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
317 2
LeetCode------找到所有数组中消失的数字(6)【数组】
这篇文章介绍了LeetCode上的"找到所有数组中消失的数字"问题,提供了一种解法,通过两次遍历来找出所有未在数组中出现的数字:第一次遍历将数组中的每个数字对应位置的值增加数组长度,第二次遍历找出所有未被增加的数字,即缺失的数字。
|
前端开发
LeetCode------移动零(5)【数组】
这篇文章介绍了LeetCode上的"移动零"问题,提出了一种使用双指针的原地操作解法,该方法首先将非零元素移动到数组前端并保持相对顺序,然后填充后续位置为零,以达到题目要求。
【LeetCode-每日一题】 删除排序数组中的重复项
【LeetCode-每日一题】 删除排序数组中的重复项
89 4
|
索引
Leetcode第三十三题(搜索旋转排序数组)
这篇文章介绍了解决LeetCode第33题“搜索旋转排序数组”的方法,该问题要求在旋转过的升序数组中找到给定目标值的索引,如果存在则返回索引,否则返回-1,文章提供了一个时间复杂度为O(logn)的二分搜索算法实现。
101 0
Leetcode第三十三题(搜索旋转排序数组)
LeetCode第81题搜索旋转排序数组 II
文章讲解了LeetCode第81题"搜索旋转排序数组 II"的解法,通过二分查找算法并加入去重逻辑来解决在旋转且含有重复元素的数组中搜索特定值的问题。
LeetCode第81题搜索旋转排序数组 II

热门文章

最新文章