bisect

基本信息

文件:bisect.py
属性:[’__builtins__’,
‘__cached__’,
‘__doc__’,
‘__file__’,
‘__loader__’,
‘__name__’,
‘__package__’,
‘__spec__’,
‘bisect’,
‘bisect_left’,
‘bisect_right’,
‘insort’,
‘insort_left’,
‘insort_right’]
作用:对有序数组进行插入查询处理,可插入也可不插入返回插入的索引位置
原理:二分法查询
别名:bisect等价于bisect_right,insort等价于insort_right
在这里插入图片描述

应用示例

  • 只返回插入索引位置,不插入
    • bisect.bisect 返回插入的索引位置,重复数值默认返回右边位置
      在这里插入图片描述
    • 指定处理重复数值方式
      • bisect.bisect_left 若重复,返回左边位置
      • bisect.bisect_right 若重复,返回右边位置
        在这里插入图片描述
  • 插入数值
    • bisect.insort 插入数,重复的默认插入右边位置
      在这里插入图片描述
      结果看不出重复数值插入哪边,其实是对应disect,默认右边位置
    • 指定处理重复数值方式
      • bisect.insort_left 若重复,插入到左边位置
      • bisect.insort_right 若重复,插入到右边位置
        在这里插入图片描述
        两个函数的操作结果是一样的,然而其插入的位置不同,对应disect_left和disect_right

源码解析

在这里插入图片描述
在这里插入图片描述
两者的区别在于判断条件时,等号放哪一边
i f   a [ m i d ] &lt; x : l o = m i d + 1    l e f t i f   a [ m i d ] ≤ x : l o = m d i + 1    r i g h t if \ a[mid]&lt;x : lo=mid+1 \ \ left \\ if \ a[mid] \leq x:lo=mdi+1 \ \ right if a[mid]<x:lo=mid+1  leftif a[mid]x:lo=mdi+1  right
另外,入参可以指定区间【lo,hi】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值