Python寻找两个有序数组的中位数实例详解


Posted in Python onDecember 05, 2018

Python寻找两个有序数组的中位数

Python寻找两个有序数组的中位数实例详解

审题:

1.找出意味着这是一个查找算法题

2.算法复杂度log级别,就是提示你是二分查找

3.二分查找实现一般为递归

 (1)递归包括递归体
 (2)终止条件

思路:

定理:

1.有序数组中有一半的元素小于等于数组的中位数,有一半的元素大于等于中位数(如果数组中元素个数是奇数,那么这里的一半并不是严格意义的1/2)

2.如果我们去掉其中一个数组比中位数小的k个数,再去掉另一个数组中比中位数大的k个数,得到的合并子数组的中位数和原来的中位数相同。

eg:[1,2,3],[1,2,3] => [1,1,2,2,3,3]

根据定理去除元素[2,3],[1,2] => [1,2,2,3]中位数没变。我用了特殊的例子解释,你可以自行换一个试一试。如果两个的数组长度不一样的时候,不能去掉各自的一半,要去掉相同的个数,下面会细说

解题思路:

假设两个数组的中位数分别是a[m1],b[m2]

1.if a[m1] == b[m2] ,那么刚好有一半的元素小于a[m1],那么a[m1]就是要找的中位数。参考上面的列子

2.if a[m1] < b[m2],根据定理1可知,这个中位数只可能出现在a[n1/2 ~ n1-1]或者b[0 ~ n2/2].也就是说合并这两个数组的中位数和原来的数组合并的数组的中位数是一样的。 根据定理2可知:

1.数组长度一样的时候,去除掉一半是合理的。

2.数组长度不一样,这么做中位数可能发生变化。解决方案就是去除掉相同个数的元素。why?假设n1 < n2, 两个数组就去掉n1/2个元素。那就不在是上面的范围(a[n1/2 ~ n1-1]或者b[0 ~ n2/2]),而是a[n1/2 ~ n1-1]或者b[0 ~ (-n1/2+n2-1)].

结论就是:只能删除a的n1/2(向下取整)

3.if a[m1] > b[m2],和上面分析类似,中位数只能出现在a的前半段或者b的后半段。也就是说a[0 ~ n1/2]和b[n1/2 ~ n2-1]的中位数和原来的中位数相同。

参考:LeetCode参考答案

class Solution:
  def findMedianSortedArrays(self, nums1, nums2):
    """
    :type nums1: List[int]
    :type nums2: List[int]
    :rtype: float
    """
    m, n = len(nums1), len(nums2)
    if m > n:
      nums1, nums2, m, n = nums2, nums1, n, m
    if n == 0:
      raise ValueError
    imin, imax, half_len = 0, m, (m + n + 1) // 2
    while imin <= imax:
      i = (imin + imax) // 2
      j = half_len - i
      if i < m and nums2[j-1] > nums1[i]:
        # i is too small, must increase it
        imin = i + 1
      elif i > 0 and nums1[i-1] > nums2[j]:
        # i is too big, must decrease it
        imax = i - 1
      else:
        # i is perfect
        if i == 0: max_of_left = nums2[j-1]
        elif j == 0: max_of_left = nums1[i-1]
        else: max_of_left = max(nums1[i-1], nums2[j-1])
        if (m + n) % 2 == 1:
          return max_of_left
        if i == m: min_of_right = nums2[j]
        elif j == n: min_of_right = nums1[i]
        else: min_of_right = min(nums1[i], nums2[j])
        return (max_of_left + min_of_right) / 2.0

总结

以上所述是小编给大家介绍的Python寻找两个有序数组的中位数,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
Python多维/嵌套字典数据无限遍历的实现
Nov 04 Python
Python Socket编程详细介绍
Mar 23 Python
用Python写王者荣耀刷金币脚本
Dec 21 Python
Python实现TCP探测目标服务路由轨迹的原理与方法详解
Sep 04 Python
Django+uni-app实现数据通信中的请求跨域的示例代码
Oct 12 Python
Python实现打印实心和空心菱形
Nov 23 Python
Python基础之变量基本用法与进阶详解
Jan 03 Python
appium+python adb常用命令分享
Mar 06 Python
Windows 平台做 Python 开发的最佳组合(推荐)
Jul 27 Python
python实现单机五子棋
Aug 28 Python
在pycharm中使用pipenv创建虚拟环境和安装django的详细教程
Nov 30 Python
Python爬虫之Selenium库的使用方法
Jan 03 Python
解决Python下imread,imwrite不支持中文的问题
Dec 05 #Python
python批量下载网站马拉松照片的完整步骤
Dec 05 #Python
解决python3中cv2读取中文路径的问题
Dec 05 #Python
利用Python求阴影部分的面积实例代码
Dec 05 #Python
python之cv2与图像的载入、显示和保存实例
Dec 05 #Python
python存储16bit和32bit图像的实例
Dec 05 #Python
Python随机生成身份证号码及校验功能
Dec 04 #Python
You might like
《魔兽争霸3:重制版》翻车了?你想要的我们都没有
2019/11/07 魔兽争霸
一个完整的PHP类包含的七种语法说明
2015/06/04 PHP
使用正则去除php代码中的注释方法
2016/11/03 PHP
jquery ajax 简单范例(界面+后台)
2013/11/19 Javascript
JS字符串拼接在ie中都报错的解决方法
2014/03/27 Javascript
jQuery学习笔记之创建DOM元素
2015/01/19 Javascript
JavaScript设置、获取、清除单值和多值cookie的方法
2015/11/17 Javascript
JavaScript学习笔记之数组求和方法
2016/03/23 Javascript
移动适配的几种方案(三种方案)
2016/11/25 Javascript
JS插件plupload.js实现多图上传并显示进度条
2016/11/29 Javascript
js实现常见的工具条效果
2017/03/02 Javascript
原生js实现验证码功能
2017/03/16 Javascript
微信小程序页面间通信的5种方式
2017/03/31 Javascript
JS+Ajax实现百度智能搜索框
2017/08/04 Javascript
详解vue几种主动刷新的方法总结
2019/02/19 Javascript
vue使用Font Awesome的方法步骤
2019/02/26 Javascript
微信小程序select下拉框实现效果
2019/05/15 Javascript
jQuery高级编程之js对象、json与ajax用法实例分析
2019/11/01 jQuery
[40:50]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS LGD第四场
2014/05/24 DOTA
[03:49]DOTA2 2015国际邀请赛中国区预选赛第二日现场百态
2015/05/27 DOTA
自己使用总结Python程序代码片段
2015/06/02 Python
python如何通过protobuf实现rpc
2016/03/06 Python
Python使用plotly绘制数据图表的方法
2017/07/18 Python
pandas把dataframe转成Series,改变列中值的类型方法
2018/04/10 Python
TensorFlow实现卷积神经网络
2018/05/24 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
Python字符串和正则表达式中的反斜杠('\')问题详解
2019/09/03 Python
美国经典刺绣和字母儿童服装特卖:Smocked Auctions
2018/07/16 全球购物
波兰最大的度假胜地和城市公寓租赁运营商:Sun & Snow
2018/10/18 全球购物
牵手50台湾:专为黄金岁月的单身人士而设的交友网站
2021/02/18 全球购物
施工班组长岗位职责
2014/01/05 职场文书
求职自荐信的格式
2014/04/07 职场文书
2014年驻村干部工作总结
2014/11/17 职场文书
给上级领导的感谢信
2015/01/22 职场文书
家装业务员岗位职责
2015/04/03 职场文书
小平小道观后感
2015/06/09 职场文书