当前位置: 首页 > news >正文

Python 的标准库 bisect 模块

Python 的标准库 bisect 模块提供了一些用于维护已排序序列的高效算法,主要基于二分查找(binary search)实现。它特别适合在需要频繁插入元素并保持序列有序的场景中使用。

下面是 bisect 模块中主要的函数方法及其功能说明:


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

  • 功能​:在有序序列 a 中查找元素 x 应该插入的位置,以保持序列的有序性。如果 x 已经存在,则返回最左边的插入位置​(即第一个大于或等于 x 的位置)。
  • 参数​:
    • a:已排序的序列(通常是列表)。
    • x:要查找插入位置的元素。
    • lo:查找范围的起始索引(默认为 0)。
    • hi:查找范围的结束索引(默认为 len(a))。
  • 返回值​:插入位置的索引。

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

或等价于​ bisect.bisect(a, x, lo=0, hi=len(a))

  • 功能​:在有序序列 a 中查找元素 x 应该插入的位置,以保持序列的有序性。如果 x 已经存在,则返回最右边的插入位置​(即第一个大于 x 的位置)。
  • 参数​:与 bisect_left 相同。
  • 返回值​:插入位置的索引。

注意​:bisect_right 和 bisect 是同一个函数,bisect 是 bisect_right 的别名。


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

  • 功能​:将元素 x 插入到有序序列 a 中,保持序列的有序性。如果 x 已经存在,则插入到最左边的位置(即第一个大于或等于 x 的位置)。
  • 参数​:与 bisect_left 相同。
  • 返回值​:无(直接修改原序列 a)。

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

或等价于​ bisect.insort(a, x, lo=0, hi=len(a))

  • 功能​:将元素 x 插入到有序序列 a 中,保持序列的有序性。如果 x 已经存在,则插入到最右边的位置(即第一个大于 x 的位置)。
  • 参数​:与 bisect_right 相同。
  • 返回值​:无(直接修改原序列 a)。

注意​:insort_right 和 insort 是同一个函数,insort 是 insort_right 的别名。


使用场景总结

函数用途是否插入元素相同函数别名
bisect_left查找 x 应插入的最左位置-
bisect_right / bisect查找 x 应插入的最右位置bisect
insort_left插入 x 到最左位置-
insort_right / insort插入 x 到最右位置insort

示例代码

import bisect# 已排序列表
a = [1, 3, 4, 4, 6, 8]# 查找插入位置
print(bisect.bisect_left(a, 4))  # 输出: 2(第一个 >=4 的位置)
print(bisect.bisect_right(a, 4)) # 输出: 4(第一个 >4 的位置)# 插入元素
bisect.insort_left(a, 4)
print(a)  # 输出: [1, 3, 4, 4, 4, 6, 8]bisect.insort_right(a, 4)
print(a)  # 输出: [1, 3, 4, 4, 4, 4, 6, 8]

如果你需要更高效地在动态数据中维护有序性(比如频繁插入和查找),bisect 模块是一个非常实用的工具,比每次都重新排序要高效得多。

http://www.lryc.cn/news/609382.html

相关文章:

  • 从WebShell 与 ShellCode 免杀技术 打造适合自己的免杀技术链
  • [Oracle] 获取系统当前日期
  • 使用AssemblyAI将音频数据转换成文本
  • [Oracle] TO_DATE()函数
  • gpu instancer crowd 使用自定义材质并且只修改单个物体的材质参数
  • 机器学习 决策树基本介绍
  • [2025ICCV-目标检测方向]DuET:通过无示例任务算术进行双增量对象检测
  • 数据结构:单向链表的函数创建
  • kubernetes基础知识
  • io_cancel系统调用及示例
  • 11.消息队列
  • IDEA查看源码利器XCodeMap插件
  • LangChain4J入门:使用SpringBoot-start
  • 网络规划与设计5个阶段内容
  • 项目日记---高并发内存池整体框架
  • Python中的sys.path与PYTHONPATH全解析:模块导入路径的底层机制与最佳实践
  • 进阶向:YOLOv11模型轻量化
  • 微店所有店铺内的商品数据API接口
  • AI Competitor Intelligence Agent Team
  • io_getevents 和 io_pgetevents 系统调用及示例
  • 【Mysql】日志--错误日志、二进制日志、查询日志、慢查询日志
  • Linux进程启动后,监听端口几分钟后消失之问题分析
  • RocksDb 是什么?levelDB、LSM 树、SSTable又分别是什么?区别呢?
  • Java,八股,cv,算法——双非研0四修之路day24
  • 2025年测绘程序设计比赛--基于统计滤波的点云去噪(已获国特)
  • 【AI】文档理解
  • 旧笔记本电脑如何安装飞牛OS
  • 嵌入式学习日志——数据结构(一)
  • 渗透高级-----应急响应
  • LLM调研