力扣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)

相关推荐
kcwqxx22 分钟前
day23|leetCode 39. 组合总和 , 40.组合总和II , 131.分割回文串
c++·算法·leetcode
kitesxian26 分钟前
Leetcode155. 最小栈(HOT100)
算法
一颗青果30 分钟前
【Linux】详解shell代码实现(上)
linux·运维·服务器·前端·chrome·算法·1024程序员节
Best_Me0743 分钟前
快速排序算法-C语言
c语言·算法·排序算法
怀旧6661 小时前
Java List 集合
java·数据结构·后端·list·个人开发
Tianwen_Burning1 小时前
halcon3D 1:1切片轮廓投影技术,透过像素距离,知实际物体的尺寸
算法·3d
pursuit_csdn2 小时前
LeetCode 1072. Flip Columns For Maximum Number of Equal Rows
数据结构·算法·leetcode·力扣
ahadee2 小时前
蓝桥杯每日真题 - 第23天
c语言·vscode·算法·蓝桥杯
花糖纸木2 小时前
算法练习:76. 最小覆盖子串
c++·算法
冉佳驹2 小时前
数据结构 ——— 直接选择排序算法的实现
c语言·数据结构·算法·排序算法·直接选择排序算法