上中位数的应用

#include<iostream>
#include<vector>
#include<algorithm>
#include<string>
using namespace std;
int findMedianProcess(vector<int>arr1, int start1, int end1, vector<int>arr2, int start2, int end2) {
    if (end1 == start1) return min(arr1[start1], arr2[start2]);
    int mid1 = (start1 + end1) >> 1;
    int mid2 = (start2 + end2) >> 1;
    int offset = ((end1 - start1) % 2);  // ==0 为奇数 ==1 为偶数  
    if (arr1[mid1] == arr2[mid2]) return arr1[mid1];
    else if (arr1[mid1] >= arr2[mid2])
        return findMedianProcess(arr1, start1, mid1, arr2, mid2 + offset, end2);
    else return findMedianProcess(arr1, mid1 + offset, end1, arr2, start2, mid2);
}
int findKthNum(vector<int> arr1, vector<int> arr2, int kth) {
    if (kth <= 0 || kth >arr1.size() + arr2.size()) return 0;// 不存在 
    if (arr1.size() > arr2.size()) swap(arr1, arr2);
    int length1 = arr1.size(), length2 = arr2.size();
    if (kth <= length1) return findMedianProcess(arr1, 0, kth - 1, arr2, 0, kth - 1);
    else if (kth < length2) {
        if (arr2[kth - length1 - 1] >= arr1[length1 - 1])return arr2[kth - length1 - 1];
        else return  findMedianProcess(arr1, 0, length1 - 1, arr2, kth - length1, kth - 1);
    }
    else {
        if (arr2[kth - length1 - 1] >= arr1[length1 - 1])return arr2[kth - length1 - 1];
        else if (arr1[kth - length2 - 1] >= arr2[length2 - 1]) return arr1[kth - length2 - 1];
        else return  findMedianProcess(arr1, kth - length2, length1 - 1, arr2, kth - length1, length1 - 1);
    }

}
int findMedianProcess(vector<int>arr1, int start1, int end1, vector<int>arr2, int start2, int end2) {
    if (end1 == start1) return min(arr1[start1], arr2[start2]);
    int mid1 = (start1 + end1) >> 1;
    int mid2 = (start2 + end2) >> 1;
    int offset = ((end1 - start1) % 2);  // ==0 为奇数 ==1 为偶数  
    if (arr1[mid1] == arr2[mid2]) return arr1[mid1];
    else if (arr1[mid1] >= arr2[mid2])return findMedianProcess(arr1, start1, mid1, arr2, mid2 + offset, end2);
    else return findMedianProcess(arr1, mid1 + offset, end1, arr2, start2, mid2);

}
int getUpMedian(vector<int> arr1, vector<int> arr2) {
    int len1 = arr1.size(), len2 = arr2.size();
    if (len1 == 0 || len1 != len2) return -1;
    if (len1 == 1) return min(arr1[0], arr2[0]);
    int left1 = 0, right1 = len1 - 1;
    int left2 = 0, right2 = len2 - 1;
    while (left1 <= right1) {
        if (left1 == right1) return min(arr1[left1], arr2[left2]);
        int mid1 = (left1 + right1) / 2, mid2 = (left2 + right2) / 2;
        int offset = (right1 - left1) % 2;
        if (arr1[mid1] == arr2[mid2]) return arr1[mid1];
        else if (arr1[mid1]>arr2[mid2]) {
            right1 = mid1; left2 = mid2 + offset;
        }
        else {
            right2 = mid2; left1 = mid1 + offset;
        }
    }
    return 0;
}
int getKTopProcess(vector<int> s, vector<int> p, int k) {
    if (k <= 0 || k >s.size() + p.size()) return 0;// 不存在 
    if (s.size() > p.size())
        swap(s, p);
    int length1 = s.size(), length2 = p.size();
    // 如果k小于length1, 就相当于找arr1与arr2前k个元素的上中位数  
    if (k <= length1) return findMedianProcess(s, 0, k - 1, p, 0, k - 1);
    // 如果k在length1和length2 之间,那么就是取shoArr与lonArr在[k-length1,k-length1+length1-1]之间的上中位数  
    else if (k <=length2) {
        if (p[k - length1 - 1] >= s[length1 - 1])
            return p[k - length1 - 1];
        else return  findMedianProcess(s, 0, length1 - 1, p, k - length1, k - 1);
    }
    // 第三种情况k大于等于length2  都转换成了求中位数了  
    else {
        if (p[k - length1 - 1] >= s[length1 - 1])return p[k - length1 - 1];
        else if (s[k - length2 - 1] >= p[length2 - 1]) return s[k - length2 - 1];
        else return  findMedianProcess(s, k - length2, length1 - 1, p, k - length1, length2 - 1);
    }

}
int main()
{

    vector<int>v1 = { 0,0,1,1,1,3,3,3,4,4,5,5,11,11,12,13,13 };
    vector<int>v2 = { 2,8,18,25,31,31,39,40,41,44,45,47,50,50 };
    vector<int>v3 = { 3,3,3,4,4,5,5,11,11,12,13,13 };
    vector<int>v4 = { 18,25,31,31,39,40,41,44,45,47,50,50 };
//  cout << findMedianProcess(v3, 0, 11, v4, 0, 11);
    cout << getKTopProcess(v1, v2, 19);

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值