位置: 编程技术 - 正文

Python实现二分查找与bisect模块详解(python 二分查找函数)

编辑:rootadmin

推荐整理分享Python实现二分查找与bisect模块详解(python 二分查找函数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python二分查找代码,python二分查找算法,python二分查找例题,python二分算法,python二分算法,python二分查找代码,python二分查找算法,python二分算法,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

其实Python 的列表(list)内部实现是一个数组,也就是一个线性表。在列表中查找元素可以使用 list.index() 方法,其时间复杂度为O(n) 。对于大数据量,则可以用二分查找进行优化。

二分查找要求对象必须有序,其基本原理如下:

1.从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;

2.如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。

3.如果在某一步骤数组为空,则代表找不到。

二分查找也成为折半查找,算法每一次比较都使搜索范围缩小一半, 其时间复杂度为 O(logn)。

我们分别用递归和循环来实现二分查找:

接着对这两种实现进行一下性能测试:

执行结果如下:

可以看出循环方式比递归效率高。

bisect 模块

Python 有一个 bisect 模块,用于维护有序列表。bisect 模块实现了一个算法用于插入元素到有序列表。在一些情况下,这比反复排序列表或构造一个大的列表再排序的效率更高。Bisect 是二分法的意思,这里使用二分法来排序,它会将一个元素插入到一个有序列表的合适位置,这使得不需要每次调用 sort 的方式维护有序列表。

下面是一个简单的使用示例:

输出结果:

Bisect模块提供的函数有:

bisect.bisect_left(a,x, lo=0, hi=len(a)) :

Python实现二分查找与bisect模块详解(python 二分查找函数)

查找在有序列表 a 中插入 x 的index。lo 和 hi 用于指定列表的区间,默认是使用整个列表。如果 x 已经存在,在其左边插入。返回值为 index。

bisect.bisect_right(a,x, lo=0, hi=len(a))

bisect.bisect(a, x,lo=0, hi=len(a)) :

这2个函数和 bisect_left 类似,但如果 x 已经存在,在其右边插入。

bisect.insort_left(a,x, lo=0, hi=len(a)) :

在有序列表 a 中插入 x。和 a.insert(bisect.bisect_left(a,x, lo, hi), x) 的效果相同。

bisect.insort_right(a,x, lo=0, hi=len(a))

bisect.insort(a, x,lo=0, hi=len(a)) :

和 insort_left 类似,但如果 x 已经存在,在其右边插入。

Bisect 模块提供的函数可以分两类: bisect* 只用于查找 index, 不进行实际的插入;而 insort* 则用于实际插入。

该模块比较典型的应用是计算分数等级:

执行结果:

同样,我们可以用 bisect 模块实现二分查找:

我们再来测试一下它与递归和循环实现的二分查找的性能:

可以看到其比循环实现略快,比递归实现差不多要快一半。

Python 著名的数据处理库 numpy 也有一个用于二分查找的函数 numpy.searchsorted, 用法与 bisect 基本相同,只不过如果要右边插入时,需要设置参数 side='right',例如:

那么,我们再来比较一下性能:

可以发现 numpy.searchsorted 效率是很低的,跟 bisect 根本不在一个数量级上。因此 searchsorted 不适合用于搜索普通的数组,但是它用来搜索 numpy.ndarray 是相当快的:

numpy.searchsorted 可以同时搜索多个值:

总结

标签: python 二分查找函数

本文链接地址:https://www.jiuchutong.com/biancheng/381383.html 转载请保留说明!

上一篇:python基础教程之五种数据类型详解(python基础教程视频教程)

下一篇:python递归删除指定目录及其所有内容的方法(pythonlist删除指定位置元素)

  • 农产品收购发票使用范围
  • 收到税务局税收返还
  • 企业出租房产增值税率
  • 专项应付款和政府补助的区别是什么
  • 一般纳税人什么情况可以开3%的发票
  • 合并报表营业收入怎么算出来的
  • 代扣个人所得税现金流入哪个科目?
  • 坏账准备的会计分录怎么写例题
  • 企业现金管理办法
  • 清算备付金的会计科目
  • 其他应付款冲应收账款
  • 可以把两张发票合写在记账凭证上吗
  • 2019水利基金税率是多少
  • 土地闲置费是否可以列入生产成本
  • 预交印花税会计分录
  • 公司店铺刷单的收入怎么记账
  • 健身房属于什么经营类别
  • 餐饮行业固定资产界定
  • 资产处置收益计入哪个会计科目
  • 换汇成本怎么计算
  • 经营费用包括哪些科目明细
  • 公司0申报怎么做账
  • 财务费用的冲减什么意思
  • 购买的烟酒怎么入账科目
  • 母公司给子公司拨款要交税吗
  • 电视柜尺寸一般是多少厘米的
  • 森林里雾气弥漫,给大家带来了什么困难?
  • 使用PHP+MySql+Ajax+jQuery实现省市区三级联动功能示例
  • 实收资本和注册资本不一致的会计处理
  • uniapp 信息推送
  • 炫酷登录注册教程
  • 待抵扣进项税在贷方什么意思
  • cvg模型
  • spring bootcsdn
  • 购买超市购物卡会计分录
  • dos命令怎么转到d盘
  • 建筑行业预缴个税怎么算
  • linux中ubuntu安装教程
  • 清算的基本流程
  • 评估费用由谁承担
  • sqlServer查询当前ip地址
  • 没有实收资本可以转让吗
  • 产品包装设计费属什么费用
  • 退回货款给客户怎么做会计分录
  • 进项税销项税增值税的区别
  • 品牌代理费计入什么科目
  • 销售商品发生的销售退回属于期间费用吗
  • 房租押金不退如何处理
  • 契税为什么计入成本费用
  • 什么是资产处置收益
  • 企业办增项怎样办理
  • 如何建立一个新的群
  • 建筑企业材料费能否加计扣除
  • 基本的select命令及作用
  • sql server自动增长方式
  • win10 9月更新 问题
  • windows xp计算器
  • .ccc是什么文件
  • win8系统 Cisco VPN 442错误怎么办?解决方法介绍
  • 安装程序不运行怎么回事
  • centos6.5双网卡绑定
  • igfxem是什么软件
  • neo是什么意思中文翻译
  • win7系统ie浏览器在哪里
  • mongoose怎么用
  • git打标签命令
  • shtml精简教程让你知道什么是shtml
  • JavaScript instanceof 的使用方法示例介绍
  • jquery可以实现哪些效果
  • javascript的prompt
  • 将一个目录复制到另一个目录下
  • nodejs怎么使用
  • android线程间通信的几种方法
  • jquery生成元素
  • [置顶] [Android Studio 权威教程]最实用的快捷键
  • python 字典怎么添加数据
  • 发票查询为什么查不出来
  • 三证合一后还有税务登记证吗?
  • 个人出租房屋如何计税?看这篇
  • 四川税务专管员查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设