vbs比较两个数组里的数的大小_BAT 高频面试题:寻找两个有序数组的中位数

942315bdcbeefe0c4b60f00d72edda3f.png

本期精选题解由我们的用户“powcai”倾情撰写,一起来看看吧!

4.寻找两个有序数组的中位数力扣力扣

题目描述

给定两个大小为 m 和 n 的有序数组 nums1 和 nums2。

请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n))。

你可以假设 nums1 和 nums2 不会同时为空。

示例 1:

0f2b2695c08feb48c88675b4a3dbdf21.png

示例 2:

7f89b2c45e389cddd50031a1e8e92de2.png

解题思路:

这道题如果时间复杂度没有限定在O(log(m+n)), 我们可以用O(m+n)的算法解决,用两个指针分别指向两个数组,比较指针下的元素大小,一共移动次数为 (m+n + 1)/2,便是中位数。

首先,我们理解什么中位数:指的是该数左右个数相等。

比如:odd : [1,| 2 |,3],2 就是这个数组的中位数,左右两边都只要 1 位;

even: [1,| 2, 3 |,4],2,3 就是这个数组的中位数,左右两边 1 位;

那么,现在我们有两个数组:

num1: [a1,a2,a3,...an]

nums2: [b1,b2,b3,...bn]

[nums1[:left1],nums2[:left2] | nums1[left1:], nums2[left2:]]

只要保证左右两边个数相同,中位数就在 | 这个边界旁边产生。

如何找边界值,我们可以用二分法,我们先确定 num1 取 m1 个数的左半边,那么 num2 取 m2 = (m+n+1)/2 - m1 的左半边,找到合适的 m1,就用二分法找。

当 [ [a1],[b1,b2,b3] | [a2,..an],[b4,...bn] ]

我们只需要比较 b3 和 a2 的关系的大小,就可以知道这种分法是不是准确的!

例如:我们令:

nums1 = [-1,1,3,5,7,9]

nums2 =[2,4,6,8,10,12,14,16]

当 m1 = 4,m2 = 3,它的中位数就是median = (num1[m1] + num2[m2])/2

时间复杂度:O(log(min(m,n)))

对于代码中边界情况,大家需要自己琢磨。

代码实现:

Python 实现

fcfcf5dcc6666fa0c641f1aadaf40dd4.png

C++ 实现

0ad5dc0d96c81b961bb7a1964b51872d.png

Java 实现

474c6aaa8bd85914afbbb2f074695a78.png

本文作者:powcai

编辑&版式:霍霍

声明:本文归作者版权所有,如需转载请联系。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值