LeetCode刷题:第四题 寻找两个有序数组的中位数

阅读: 评论:0

LeetCode刷题:第四题 寻找两个有序数组的中位数

LeetCode刷题:第四题 寻找两个有序数组的中位数

题目描述:

给定两个大小为 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];}
}

注释已经给出完整解释!

转载于:.html

本文发布于:2024-01-29 17:33:15,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170652079917103.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:中位数   数组   两个   LeetCode   刷题
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23