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

        
    }
}
相关推荐
SteveSenna10 分钟前
强化学习4.1:基于价值——Q-learning
人工智能·学习·算法·机器人
少许极端11 分钟前
算法奇妙屋(四十四)-贪心算法学习之路11
java·学习·算法·贪心算法
子琦啊11 分钟前
【算法复习】数组与双指针篇
javascript·算法
ambition2024214 分钟前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论
逆境不可逃28 分钟前
LeetCode 热题 100 之 230. 二叉搜索树中第 K 小的元素 199. 二叉树的右视图 114. 二叉树展开为链表
算法·leetcode·职场和发展
一个有温度的技术博主32 分钟前
Redis Cluster 核心原理:哈希槽与数据路由实战
redis·算法·缓存·哈希算法
wfbcg43 分钟前
每日算法练习:LeetCode 15. 三数之和 ✅
算法·leetcode·职场和发展
2301_822703201 小时前
开源鸿蒙跨平台Flutter开发:跨端图形渲染引擎的类型边界与命名空间陷阱:以多维雷达图绘制中的 dart:ui 及 StrokeJoin 异常为例
算法·flutter·ui·开源·图形渲染·harmonyos·鸿蒙
y = xⁿ1 小时前
【LeetCode Hot100】双指针:分离指针
算法·leetcode
学习永无止境@1 小时前
Verilog中有符号数计算
图像处理·算法·fpga开发