1. 程式人生 > 實用技巧 >LeetCode第4題:尋找兩個有序陣列的中位數

LeetCode第4題:尋找兩個有序陣列的中位數

 double Solution::findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2)
{
if (nums1.size() > nums2.size())
{
return findMedianSortedArrays(nums2, nums1);
} int m = nums1.size();
int n = nums2.size(); //m <= n int left = , right = m, ansi=-;
int midNum1 = , midNum2 = ;
auto max = [](int a, int b)
{
return a >= b ? a : b;
};
auto min = [](int a, int b)
{
return a <= b ? a : b;
};
while (left <= right)
{
int i = (left + right) / ;
int j = (m + n + ) / - i; int i_1 = i == ? INT_MIN : nums1[i - ];
int i_0 = i == m ? INT_MAX : nums1[i]; int j_1 = j == ? INT_MIN : nums2[j - ];
int j_0 = j == n ? INT_MAX : nums2[j];
if (i_1 <= j_0)
{
ansi = i;
midNum1 = max(i_1, j_1);
midNum2 = min(i_0, j_0);
left = i + ;
}
else
{
right = i - ;
}
}
return ( == (m + n) % ) ? (double)midNum1 : (double)(midNum1 + midNum2) / ;
}