力扣4:寻找两个正序数的中位数

给定两个大小分别为 mn 的正序(从小到大)数组 nums1nums2。请你找出并返回这两个正序数组的 中位数

算法的时间复杂度应该为 O(log (m+n))

示例 1:

复制代码
输入:nums1 = [1,3], nums2 = [2]
输出:2.00000
解释:合并数组 = [1,2,3] ,中位数 2

示例 2:

复制代码
输入:nums1 = [1,2], nums2 = [3,4]
输出:2.50000
解释:合并数组 = [1,2,3,4] ,中位数 (2 + 3) / 2 = 2.5

思想:先按照归并排序进行合并两个有序表。然后按照合并后的顺序表偶数个和奇数个数据分别进行寻找中位数。

代码:

复制代码
double findMedianSortedArrays(int* nums1, int nums1Size, int* nums2, int nums2Size){
	int *nums=(int*)malloc(sizeof(int)*(nums1Size+nums2Size));
	int i=0,j=0,k=0;
	while(i<=nums1Size-1&&j<=nums2Size-1){
		if(nums1[i]<nums2[j]){
			nums[k++]=nums1[i++];
		}else{
			nums[k++]=nums2[j++];
		}
	}
	while(i<=nums1Size-1) nums[k++]=nums1[i++];
	while(j<=nums2Size-1) nums[k++]=nums2[j++];
	if((nums1Size+nums2Size)%2==0){
        //数组下标从0开始
		return ((double)nums[(nums1Size+nums2Size)/2]+(double)nums[(nums1Size+nums2Size)/2-1])/2;
	}else{
		 return (double)nums[(nums1Size+nums2Size)/2];
	}
}

时间复杂度O(log(m+n)),空间复杂度O(1)

相关推荐
wuweijianlove2 分钟前
算法复杂度的实验估算与误差分布建模的技术7
算法
佳xuan34 分钟前
简而言之c++
c++·算法
变量未定义~1 小时前
星际争霸、宝石塔的亮度差异、寻找食物储量
算法
YL200404261 小时前
027合并两个有序链表
java·数据结构·算法·链表
MATLAB代码顾问1 小时前
【智能优化】无穷优化算法(INFO)原理与Python实现
开发语言·python·算法
炽烈小老头1 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表
Zephyr_01 小时前
java数据结构
java·数据结构
SilentSamsara2 小时前
迭代器协议:`__iter__` / `__next__` 的完整执行流程
开发语言·人工智能·python·算法·机器学习
AI科技星2 小时前
算法联盟ROOT · 全域数学物理卷第20、21、22分册:量子纠缠、隐形场论与时间膨胀
人工智能·算法·数学建模·数据挖掘·机器人
MATLAB代码顾问2 小时前
【智能优化】鹈鹕优化算法(POA)原理与Python实现
开发语言·python·算法