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];
        }
        

        
    }
}
相关推荐
wadesir2 小时前
Rust中的条件变量详解(使用Condvar的wait方法实现线程同步)
开发语言·算法·rust
yugi9878382 小时前
基于MATLAB实现协同过滤电影推荐系统
算法·matlab
TimberWill2 小时前
哈希-02-最长连续序列
算法·leetcode·排序算法
Morwit2 小时前
【力扣hot100】64. 最小路径和
c++·算法·leetcode
leoufung2 小时前
LeetCode 373. Find K Pairs with Smallest Sums:从暴力到堆优化的完整思路与踩坑
java·算法·leetcode
七禾页丫3 小时前
面试记录12 中级c++开发工程师
c++·面试·职场和发展
wifi chicken3 小时前
数组遍历求值,行遍历和列遍历谁更快
c语言·数据结构·算法
胡楚昊3 小时前
NSSCTF动调题包通关
开发语言·javascript·算法
Gold_Dino4 小时前
agc011_e 题解
算法
bubiyoushang8884 小时前
基于蚁群算法的直流电机PID参数整定 MATLAB 实现
数据结构·算法·matlab