【题记】在两个长度相等的排序数组中找到上中位数

int findMedianinTwoSortedAray(int* arr1, int arr1Len, int* arr2, int arr2Len ) {
    // write code here
    int mid;
    while(1){
        if(arr1Len==1){
            return *arr1>=*arr2?*arr2:*arr1;
        }else{
            int flag = arr1Len%2;
            mid=flag==0?arr1Len/2-1:arr1Len/2;
            if(arr1[mid]>arr2[mid]){//如果arr1>arr2则说明arr2[0-->mid]这部分的内容一定不包括中位数
                arr2+=mid+1-flag;//此处要注意奇数的特殊情况
                arr1Len=arr1Len/2+flag;
            }else if(arr1[mid]<arr2[mid]){//同理
                arr1+=mid+1-flag;
                arr1Len=arr1Len/2+flag;
            }else{
                return arr1[mid];
            }
        }
    }
    return 1;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值