Leetcode 4 寻找两个有序数组的中位数(还有一种解法没有学习)

题目

代码分析

要达到有log的时间复杂度,可以想到一定和二分有关系,我们的普通做法就是每次都从两个数组的头出去一个,当出去总量的一半之后,就完成了。
这里我们每次都出一半,具体的,如果两个数组的总量是14,我们要找了就是第7小和第8小的数字,对于第7小的,我们首先要找第7/2=3小的数字,这就是这道题的思路。例子:
https://leetcode-cn.com/problems/median-of-two-sorted-arrays/solution/xiang-xi-tong-su-de-si-lu-fen-xi-duo-jie-fa-by-w-2/
中的解法3

代码实现

class Solution {
    public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        int m=nums1.length;
        int n=nums2.length;

        int index1=(m+n+1)/2;
        int index2=(m+n+2)/2;

        return (f(nums1,0,m-1,nums2,0,n-1,index1)+f(nums1,0,m-1,nums2,0,n-1,index2))*0.5;
    }

    public int f(int[] nums1,int start1,int end1,int[] nums2,int start2,int end2,int k)
    {
         int len1=end1-start1+1;
         int len2=end2-start2+1;
         if(len1>len2)
         {
             return f(nums2,start2,end2,nums1,start1,end1,k);
         }
         if(len1==0)
         {
             return nums2[start2+k-1];   
         }
         if(k==1)
         {
             return Math.min(nums1[start1],nums2[start2]);
         }   
         int index1=start1+Math.min(k/2,len1)-1;
         int index2=start2+Math.min(k/2,len2)-1;
        if (nums1[index1] > nums2[index2]) {
            return f(nums1, start1, end1, nums2, index2 + 1, end2, k - index2 + start2 - 1);
        } else {
            return f(nums1, index1 + 1, end1, nums2, start2, end2, k - index1 + start1 - 1);
        }
    }
}

学习情况

1次

全部评论

相关推荐

03-03 19:02
已编辑
东华理工大学 Node.js
点赞 评论 收藏
分享
04-16 10:27
已编辑
美团_Saas_后端开发
今天周一休息,突发奇想写一篇阶段总结。如题,我已经去了一个和Java彻底毫无关联的行业。曾经我以为自己能在计算机行业发光发热,拿到美团offer那会感觉自己天都亮了。没想到刚入行一年多就当了逃兵。从最开始的热爱到现在一看到代码就厌恶,不知道自己经历了什么。所以我去干什么了?答案是:在成都当了租房销售。上班那会压力大了就念叨着去干租房中介,但是一直下不去这个决心,想着自己学了四年多的计算机知识,终究还是不甘心。终于在某一天准备八股文的时候,看着无数篇和工作内容关系不大的理论知识,那一刻下定决心,决定尝试一下销售行业,也算是给自己一个交代。后面阴差阳错的投了成都自如去当租房管家,没想到面试很顺利,在当天一百多个面试的人里面,我成为了为数不多通过的几个幸运儿之一。目前已经培训通过,正式入职,也开了单,有压力但是每天过得很开心,真心喜欢那种和人交流的感觉,哪怕是最后没有选择找我租房。说这些也是想告诉那些大三,大四正在找Java实习而焦虑的同学:你们现在还年轻,选择很多,容错率也很高,可以尽情去尝试自己喜欢的行业和工作。不用因为某一次的面试没通过或者简历石沉大海而焦虑,更不用因为身边人都在挤编程的独木桥就强迫自己跟风。也算是自己的碎碎念吧,也希望自己能在新的领域取得一点小成就。也祝牛油工作顺利!
沉淀小子:干啥都不丢人啊,生存是必须要的,销售很考验一个人综合素质能力的,好的销售人脉和资源可不比写字楼的白领差啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务