leetcode-4

https://leetcode-cn.com/problems/median-of-two-sorted-arrays/

思路:求中位数转化为求topk,难点在于如何2个数组中求出topk。topk思路为每次比较为k/2,当k==1时,就是所求答案

int findTopk(vector<int>& nums1, vector<int>& nums2, int k) {
    //cout << "top:" << k << endl;
    int nums1_len = nums1.size();
    int nums2_len = nums2.size();
    if (nums1_len == 0 && nums2_len == 0) {
        return 0;
    }
    if (nums1_len == 0) {
        return nums2[k - 1];
    }
    if (nums2_len == 0) {
        return nums1[k - 1];
    }

    int nums1_idx = 0;
    int nums2_idx = 0;
    int nums1_new_idx = 0;
    int nums2_new_idx = 0;
    while (k != 1) {
        int idx = k / 2 - 1;

       //获取每个数组中的下标
        nums1_new_idx = min(nums1_idx + idx, nums1_len - 1);
        nums2_new_idx = min(nums2_len - 1, nums2_idx + idx);
        if (nums1[nums1_new_idx] > nums2[nums2_new_idx]) {
            k = k - (nums2_new_idx - nums2_idx + 1);
            nums2_idx = nums2_new_idx + 1;
        } else {
            k = k - (nums1_new_idx - nums1_idx + 1);
            nums1_idx = nums1_new_idx + 1;
        }

        //针对数据边界的问题加的条件,k+nums2_idx获取当前topk中的k,-1为数组中的下标
        if (nums1_idx == nums1_len) {
            return nums2[k + nums2_idx - 1];
        }
        if (nums2_idx == nums2_len) {
            return nums1[k + nums1_idx - 1];
        }
        //cout << "loop " <<  k << " " << nums1_idx << " " << nums2_idx << endl;
    }
    //cout << nums1_idx << " " << nums2_idx << " " << min(nums1[nums1_idx], nums2[nums2_idx]) << endl;
    return min(nums1[nums1_idx], nums2[nums2_idx]);
}

double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
    int nums1_len = nums1.size();
    int nums2_len = nums2.size();
    if ((nums1_len + nums2_len) % 2 == 1) {
        return findTopk(nums1, nums2, (nums1_len + nums2_len) / 2.0 + 1);
    } else {
        return (findTopk(nums1, nums2, (nums1_len + nums2_len) / 2) + findTopk(nums1, nums2, (nums1_len + nums2_len) / 2 + 1)) / 2.0;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值