程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
您现在的位置: 程式師世界 >> 編程語言 >  >> 更多編程語言 >> Python

python:bisect查找和排序

編輯:Python

bisect可以實現二分查找和插入。其函數有bisect_left,bisect_right和insert_left,insert_right。分別對應查找和插入。
由於數組中存在重復元素,所以才有left和right的區分。其含義分別是在元素的左側以及右側。
其定義如下:

定義作用bisect_right(a, x, lo=0, hi=None)在數組a中查找元素x,返回符合條件的最右側下標bisect_left(a, x, lo=0, hi=None)在數組a中查找元素x,返回符合條件的最左側下標insort_right(a, x, lo=0, hi=None)在數組a中插入元素x,插入位置在返回符合條件的最右側insort_left(a, x, lo=0, hi=None)在數組a中插入元素x,插入位置在返回符合條件的最左側

查找的示例代碼:

import bisect
arr = [0,1,1,1,2,2,4,4,6,6,7,8,9,9,10]
pos_right = bisect.bisect_right(arr,6)
pos_left = bisect.bisect_left(arr,6)
print(pos_right,pos_left)

結果為:

10 8

插入示例:

arr1 = [0,1,1,1,2,2,4,4,6,6,7,8,9,9,10]
arr2 = [0,1,1,1,2,2,4,4,6,6,7,8,9,9,10]
bisect.insort_right(arr1,5)
bisect.insort_left(arr2,5)
print(arr1)
print(arr2)

返回的結果其實是一樣的。


  1. 上一篇文章:
  2. 下一篇文章:
Copyright © 程式師世界 All Rights Reserved