zoukankan      html  css  js  c++  java
  • leetcode第二题--Median of Two Sorted Arrays

    Problem:There are two sorted arrays A and B of size m and n respectively. Find the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)).

    首先要知道什么是median,也就是我们所知的中位数,处于中间位置的数,很简单,如果长度为奇数,那么中位数就是中间的数,如,1,2,4,那么中位数就是2。如果长度为偶数,那就是中间两个数的均值,如,1,2,3,4,那么中位数就是2.5。

    Suool在http://blog.csdn.net/suool/article/details/38343457中提到的第一种方法如下:

    合并,排序,找中间位置的值就好:

    class Solution {  
    public:  
        double findMedianSortedArrays(int A[], int m, int B[], int n) {  
            // Start typing your C/C++ solution below  
            // DO NOT write int main() function  
            int *a=new int[m+n];  
              
            memcpy(a,A,sizeof(int)*m);  
            memcpy(a+m,B,sizeof(int)*n);  
              
            sort(a,a+n+m);  
              
            double median=(double) ((n+m)%2? a[(n+m)>>1]:(a[(n+m-1)>>1]+a[(n+m)>>1])/2.0);  
              
            delete a;  
              
            return median;  
        }  
    };  

    但是我们可以看到中间有个排序sort(a,a+n+m)这个复杂度已经是超过要求了。但是奇怪的是在leetcode上测试居然通过了。

    还有一种方法在上述链接中也提到了,就是先在两个数组中找第k个值,然后根据奇数偶数确定k就好。但是该链接上给出的代码是错误了,通过不了。

    我找到了原因,把正确的贴出如下:

    class Solution  
    {  
    private:  
        double findKth(int a[], int m, int b[], int n, int k)  
        {  //find kth small
            int i = 0;  
            int j = 0;  
            int index = 1;  
            int kth;  
            if (m == 0)  
                return b[k-1];  
            if (n == 0)  
                return a[k-1];  
            if (k ==1)  
                return a[0]>b[0] ? b[0] : a[0];  
            while(index <= k && i < m && j < n)  
            {  
                if( a[i] >= b[j])  
                {  
                    index ++;  
                    kth = b[j];  
                    j ++;  
                }  
                else  
                {  
                    index ++;  
                    kth = a[i];  
                    i ++;  
                }  
            }  
            if( index <= k && j == n)  // must be <= can't be only <
            {  
                kth = a[i+k-index];  
            }  
            if (index <= k && i == m)  
                kth = b[j+k-index];  
            return kth;  
        }  
    public:  
        double findMedianSortedArrays(int A[], int m, int B[], int n)  
        {  
            int total = m + n;  
            if (total & 0x1) // odd
                return findKth(A, m, B, n, (total + 1) / 2);  
            else   // even
                return (findKth(A, m, B, n, total / 2)  
                        + findKth(A, m, B, n, total / 2 + 1)) / 2;  
        }  
    };  

    原链接的代码在线测试时会出现本来是100000.5的却错误输出为100000.25,原因是原作者在k==2的时候假设错误了,并且在之后的index中没有考虑到index到了k值但是还没有达到第k小,要用小于等于号,而不是小于号,详见上述代码中注释。修改后就通过了。

    暂且知道这两种方法,暂不深究了,继续前行

  • 相关阅读:
    唯一的确定一棵二叉树
    Educational Codeforces Round 55 (Rated for Div. 2)
    524 (Div. 2) Masha and two friends
    单链表实现n(n≥20)的阶乘
    表达式的后缀表示
    UPCOJ2012 The King’s Walk(dp)
    第七届山东省省赛D Swiss-system tournament(归并排序)
    第七届山东省省赛C Proxy(最短路)
    hihocoder1185 连通性·三
    hihocoder1184 连通性二·边的双连通分量
  • 原文地址:https://www.cnblogs.com/higerzhang/p/4010005.html
Copyright © 2011-2022 走看看