两个排序数组的中位数

求两个排序数组中位数,这道题是很有意思的一道题目,算法导论中9.3-8题,这题必须在O(logn)的时间复杂度求解,否则肯定悲剧。。。

这题有个关键的条件,那就是这两个数组长度相等

思路如下:

数组A:1, 3, 5, 7, 9

数组B:2, 4, 6, 8, 10

首先取二者的中位数,在O(1)时间复杂度内求出,那么数组A的midValue = 5,数组B的midValue = 6,则较小的元素midValue的左边所有元素,也就是midPosition个,和较大元素右边的所有元素,都要去掉,由于去掉的元素占所有元素的一 半,所以复杂度为O(logn)。只需要移动begin和end的position即可。

第一轮:

数组A:1, 3, 5, 7, 9

数组B:2, 4, 6, 8, 10

第二轮:

数组A:1, 3, 5, 7, 9

数组B:2, 4, 6, 8, 10

只剩下两个元素,由于这种情形下midValue始终是偏左的元素,因此循环无法退出,所以满足lhsBegin == lhsEnd - 1和 rhsBegin == rhsEnd - 1时,循环退出!

如果两个

上述情形是当数组中有两个及以上元素才成立,必须考虑两个数组只存在一个元素的情形,那么直接取较小的元素即可


    #include <iostream>  
      
    using namespace std;  
      
    int findMidValue(int *lhs, int *rhs, int size)  
    {  
        if (lhs == NULL || rhs == NULL || size <= 0)  
            return -1;  
      
        int lhsBegin = 0;  
        int rhsBegin = 0;  
        int lhsEnd = size - 1;  
        int rhsEnd = size - 1;  
        int result;  
      
        while ((lhsBegin < lhsEnd && rhsBegin < rhsEnd))  
        {  
            if ((lhsBegin == lhsEnd - 1 && rhsBegin == rhsEnd - 1))  
                break;  
            int lhsMid = (lhsBegin + lhsEnd) >> 1;  
            int rhsMid = (rhsBegin + rhsEnd) >> 1;  
              
            if (lhs[lhsMid] == rhs[rhsMid])  
            {  
                result = lhs[lhsMid];  
                break;  
            }  
            else if (lhs[lhsMid] < rhs[rhsMid])  
            {  
                lhsBegin = lhsMid;  
                rhsEnd = rhsMid;  
            } else  
            {  
                lhsEnd = lhsMid;  
                rhsBegin = rhsMid;  
            }  
        }  
      
        if (lhsBegin == lhsEnd && rhsBegin == rhsEnd)  
            result = min(lhs[lhsBegin], rhs[rhsBegin]);  
        else if (lhsBegin == lhsEnd - 1 && rhsBegin == rhsEnd - 1)  
        {  
            if (lhs[lhsBegin] < rhs[rhsBegin])  
            {  
                result = min(lhs[lhsEnd], rhs[rhsBegin]);  
            }  
            else  
            {  
                result = min(lhs[lhsBegin], rhs[rhsEnd]);  
            }  
        }  
      
        return result;  
    }  
      
    void main()  
    {  
        int lhs[] = {1, 2, 3, 4};  
        int rhs[] = {0, 2, 3, 4};  
        const int size = sizeof lhs / sizeof *lhs;  
        int result = findMidValue(lhs, rhs, size);  
        cout << "mid value = " << result << endl;  
    }  


     
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值