LeetCode hot100-68

https://leetcode.cn/problems/median-of-two-sorted-arrays/description/?envType=study-plan-v2\&envId=top-100-liked

java 复制代码
4. 寻找两个正序数组的中位数
已解答
困难
相关标签
相关企业
给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。

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

这题的时间复杂度显然需要二分,没什么思路,题解一大堆字又是复杂题懒得看了。LeetCode对时间复杂度的校验根本不严格,写了个O(m+n)的也通过了。

java 复制代码
class Solution {
    public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        int  n1=nums1.length, n2=nums2.length;
        int[] num = new int[n1+n2];
        int i=0,j=0,k=0;
        while(i<n1&&j<n2){
            if(nums1[i]<nums2[j]){
                num[k++]=nums1[i++];
            }else{
                num[k++]=nums2[j++];
            }

        }
        while(i < n1){
            num[k++]=nums1[i++];
        }
        while(j < n2){
            num[k++]=nums2[j++];
        }
        //System.out.println(k);


        if(k%2 ==0){
            return (num[k/2]+num[k/2-1])/2.0;
        } else{
            return num[k/2];
        }
        

        
    }
}
相关推荐
圣保罗的大教堂20 分钟前
leetcode 2799. 统计完全子数组的数目 中等
leetcode
SsummerC27 分钟前
【leetcode100】组合总和Ⅳ
数据结构·python·算法·leetcode·动态规划
YuCaiH1 小时前
数组理论基础
笔记·leetcode·c·数组
2301_807611491 小时前
77. 组合
c++·算法·leetcode·深度优先·回溯
SsummerC2 小时前
【leetcode100】零钱兑换Ⅱ
数据结构·python·算法·leetcode·动态规划
好易学·数据结构3 小时前
可视化图解算法:二叉树的最大深度(高度)
数据结构·算法·二叉树·最大高度·最大深度·二叉树高度·二叉树深度
程序员-King.3 小时前
day47—双指针-平方数之和(LeetCode-633)
算法·leetcode
阳洞洞3 小时前
leetcode 1035. Uncrossed Lines
算法·leetcode·动态规划·子序列问题
小鹿鹿啊4 小时前
C语言编程--15.四数之和
c语言·数据结构·算法
rigidwill6664 小时前
LeetCode hot 100—最长有效括号
数据结构·c++·算法·leetcode·职场和发展