寻找两个正序数组的中位数
寻找两个正序数组的中位数
示例:
输入:nums1 = [1,3], nums2 = [2]
输出:2.00000
解释:合并数组 = [1,2,3] ,中位数 2
输入:nums1 = [1,2], nums2 = [3,4]
输出:2.50000
解释:合并数组 = [1,2,3,4] ,中位数 (2 + 3) / 2 = 2.5
输入:nums1 = [0,0], nums2 = [0,0]
输出:0.00000
代码:
# -*- coding:utf-8 -*-
# @author: kayb
# @time: 2021/1/30 下午6:05
class Solution:
def findMedianSortedArrays(self, nums1, nums2) -> float:
new_array = list()
i = 0
j = 0
len1 = len(nums1)
len2 = len(nums2)
# 有一个数组为空 则直接拼接
if len1 == 0 or len2 == 0:
new_array = nums1 + nums2
else:
# 依次对比两个序列的开始值 哪个小则保存哪个 直到结束
while i < len1 or j < len2:
if nums1[i] < nums2[j]:
new_array.append(nums1[i])
i += 1
else:
new_array.append(nums2[j])
j += 1
# 有一个循环结束 则将剩余添加的后面
if i == len1:
new_array = new_array + nums2[j:]
break
if j == len2:
new_array = new_array + nums1[i:]
break
# 取值
mid, _ = divmod(len(new_array), 2)
if _:
mid_val = new_array[mid]
else:
mid_val = (new_array[mid] + new_array[mid-1])/2
return mid_val
if __name__ == '__main__':
s = Solution()
nums1 = [1,3]
nums2 = [2]
print(s.findMedianSortedArrays(nums1, nums2))
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· .NET 9 new features-C#13新的锁类型和语义
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 《SpringBoot》EasyExcel实现百万数据的导入导出