直接上代码:
double findMedianSortedArrays(int* nums1, int nums1Size, int* nums2, int nums2Size) { int nums[5000], numsSize = nums1Size + nums2Size; int i = 0,j = 0,k = 0; //将两个有序的数组合并 for(i = 0; j < nums1Size && k < nums2Size; i++){ if(nums1[j] > nums2[k]) { nums[i] = nums2[k++]; } else { nums[i] = nums1[j++]; } } //将剩余的合并 while(j < nums1Size) nums[i++] = nums1[j++]; while(k < nums2Size) nums[i++] = nums2[k++]; //这里必须是2.0,因为返回的是double类型 if(numsSize % 2 == 0) { return (nums[numsSize / 2] + nums[numsSize / 2 - 1]) / 2.0; } else { return nums[numsSize / 2]; } }
注释已经给出完整解释!