Median of Two Sorted Arrays
Median of Two Sorted Arrays
There are two sorted arrays nums1 and nums2 of size m and n respectively.
Find the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)).
You may assume nums1 and nums2 cannot be both empty.
Example 1:
nums1 = [1, 3]
nums2 = [2]
The median is 2.0
Example 2:
nums1 = [1, 2]
nums2 = [3, 4]
The median is (2 + 3)/2 = 2.5
Code:
//
// main.cpp
// 中位数
//
// Created by mac on 2019/7/17.
// Copyright © 2019 mac. All rights reserved.
//
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
class Solution {
public:
double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
double midenum;
if (nums1.size()>0 && nums2.size()>0) {
for (int i=0; i<nums2.size(); ++i) {
nums1.push_back(nums2[i]);
}
sort(nums1.begin(), nums1.end());
if (nums1.size()%2==0) {
midenum=(double)((double)(nums1[nums1.size()/2])+(double)(nums1[nums1.size()/2-1]))/2;
}else{
midenum=nums1[nums1.size()/2];
}
}else if (nums1.size()>0){
if (nums1.size()%2==0) {
midenum=((double)(nums1[nums1.size()/2])+(double)(nums1[nums1.size()/2-1]))/2;
}else{
midenum=nums1[nums1.size()/2];
}
}else{
if (nums2.size()%2==0) {
midenum=((double)(nums2[nums2.size()/2])+(double)(nums2[nums2.size()/2-1]))/2;
}else{
midenum=nums2[nums2.size()/2];
}
}
return midenum;
}
};
int main(int argc, const char * argv[]) {
vector<int> a,b;
// a.push_back(1);
// a.push_back(2);
b.push_back(2);
b.push_back(3);
Solution so;
cout<<so.findMedianSortedArrays(a, b)<<endl;
return 0;
}
运行结果
2.5
Program ended with exit code: 0
参考文献
未经本人准许,禁止转载.

浙公网安备 33010602011771号