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

相关推荐
charlie11451419126 分钟前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎2 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎2 小时前
leetcode_day10_筑基期_《绝境求生》
算法
j_jiajia2 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
源代码•宸2 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
一叶知秋064 小时前
数据结构-什么是队列?
数据结构·队列
Jasmine_llq4 小时前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计
小棠师姐4 小时前
支持向量机(SVM)入门:超平面与核函数的通俗解释
算法·python机器学习·支持向量机svm·超平面可视化·核函数应用
zhongvv4 小时前
对单片机C语言指针的一些理解
c语言·数据结构·单片机·指针·汇编语言
im_AMBER4 小时前
Leetcode 102 反转链表
数据结构·c++·学习·算法·leetcode·链表