寻找两个正序数值的中位数

时间复杂度是log(m+n);

解题思路:
先求出两数组的总长度,分奇数和偶数情况,
奇数时,将n/2不断÷2,在两个数组中不断切去较小的一些数,直到第n/2个数就是中位数;偶数时求出n/2和n/2+1的和再除2.
```cpp
class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
    
    int n = nums1.size()+nums2.size();
     if(n%2==0)
     {
            int left = find(nums1,0,nums2,0,n/2);
            int right = find(nums1,0,nums2,0,n/2+1);
            return (left+right)/2.0;//写2.0表示返回浮点型
     }
     else{
         return find(nums1,0,nums2,0,n/2+1);
     }
    
    }
     int find(vector<int>& nums1,int i,vector<int>& nums2,int j,int k)
     {
         if(nums1.size()-i>nums2.size()-j)
            return find(nums2,j,nums1,i,k);//保证个数较小的数组在前面
         if(nums1.size()==i)
            return nums2[j+k-1];
        if(k==1)
            return min(nums1[i],nums2[j]);    
            //中位数所在的下标的后一位
            int md1 = min((int)nums1.size(),i+k/2);//num1.size()必须转换为int,可能因为它是unsigned int。
            int md2 = j+k/2;
            if(nums1[md1-1]<nums2[md2-1])
            {
               return find(nums1,md1,nums2,j,k-(md1-i));
            }
            else{
              return  find(nums1,i,nums2,md2,k-(md2-j));
            }

         
     }
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值