LeetCode刷题:第四题 寻找两个有序数组的中位数
2019-09-21 20:18
351 查看
原文链接:http://www.cnblogs.com/lihanwen/p/10529227.html
题目描述:
给定两个大小为 m 和 n 的有序数组
nums1和
nums2。
请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n))。
你可以假设
nums1和
nums2不会同时为空。
示例 1:
nums1 = [1, 3] nums2 = [2] 则中位数是 2.0
示例 2:
nums1 = [1, 2] nums2 = [3, 4] 则中位数是 (2 + 3)/2 = 2.5直接上代码:
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]; } }
注释已经给出完整解释!
转载于:https://www.cnblogs.com/lihanwen/p/10529227.html
相关文章推荐
- 【LeetCode】第四题:寻找两个有序数组的中位数
- leetcode第四题:寻找两个有序数组的中位数
- Leetcode:4.寻找两个有序数组的中位数
- LeetCode 4 --寻找两个有序数组的中位数--Python
- leetcode之数组类之数组的旋转与分治类-----OJ 189/33/81/153/154 数组旋转 旋转数组搜索 88 有序数组合并 4 两个有序数组寻找第K个元素/中位数 35 寻找插入位置
- [leetcode 4] 寻找两个有序数组的中位数 python
- leetcode 寻找两个有序数组的中位数
- Leetcode(C++)——4. 寻找两个有序数组的中位数
- leetcode 寻找两个有序数组的中位数
- leetcode--寻找两个有序数组的中位数
- leetcode 寻找两个有序数组的中位数 median of two sorted arrays
- 基础算法之寻找两个有序数组的中位数(LeetCode-4)
- [leetcode] Median of Two Sorted Arrays 寻找两个有序数组的中位数
- [LeetCode]4. 寻找两个有序数组的中位数/C++
- LeetCode-4 :寻找两个有序数组的中位数 ★★★★★
- 寻找两个有序数组的中位数(LeetCode)
- LeetCode 寻找两个有序数组的中位数
- LeetCode--4. 寻找两个有序数组的中位数(Median of Two Sorted Arrays)
- leetcode: 4. 寻找两个有序数组的中位数
- LeetCode4.python实现:寻找两个有序数组中的中位数问题☆☆☆