Python?二分查找之bisect庫的使用詳解
簡介
bisect
庫是 Python 標(biāo)準(zhǔn)庫中的一部分,它提供了二分查找的功能。二分查找是一種在有序列表中查找某一特定元素的搜索算法。它的時(shí)間復(fù)雜度為 O ( log ? n ) O(\log n) O(logn),比順序查找的時(shí)間復(fù)雜度 O ( n ) O(n) O(n) 要有效率。
bisect 庫的使用
bisect
庫提供了 bisect_left
、bisect_right
、insort_left
、insort_right
四個(gè)函數(shù),用于在有序列表中查找或插入元素。
bisect_left
bisect_left
函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,返回該位置,如果元素已經(jīng)存在,則返回它的左邊位置。
函數(shù)原型如下:
bisect.bisect_left(a, x, lo=0, hi=len(a), *, key=None)
其中,a
是一個(gè)有序列表,x
是要查找的元素,lo
和 hi
是查找范圍的左右邊界,key
是一個(gè)函數(shù),用于從列表中提取比較的鍵值。
示例:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 查找元素 4 的位置 print(bisect.bisect_left(a, 4)) # 4 # 查找元素 6 的位置 print(bisect.bisect_left(a, 6)) # 5
bisect_right
bisect_right
函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,返回該位置,如果元素已經(jīng)存在,則返回它的右邊位置。
函數(shù)原型如下:
bisect.bisect_right(a, x, lo=0, hi=len(a), *, key=None)
其中,a
是一個(gè)有序列表,x
是要查找的元素,lo
和 hi
是查找范圍的左右邊界,key
是一個(gè)函數(shù),用于從列表中提取比較的鍵值。
示例:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 查找元素 4 的位置 print(bisect.bisect_right(a, 4)) # 4 # 查找元素 6 的位置 print(bisect.bisect_right(a, 6)) # 8
除此之外,bisect_right
還可以簡寫為 bisect
:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 查找元素 4 的位置 print(bisect.bisect(a, 4)) # 4 # 查找元素 6 的位置 print(bisect.bisect(a, 6)) # 8
insort_left
insort_left
函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,然后將元素插入該位置,如果元素已經(jīng)存在,則插入到它的左邊位置。
函數(shù)原型如下:
bisect.insort_left(a, x, lo=0, hi=len(a), *, key=None)
其中,a
是一個(gè)有序列表,x
是要插入的元素,lo
和 hi
是查找范圍的左右邊界,key
是一個(gè)函數(shù),用于從列表中提取比較的鍵值。
示例:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 插入元素 4 bisect.insort_left(a, 4) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10] # 插入元素 6 bisect.insort_left(a, 6) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]
insort_right
insort_right
函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,然后將元素插入該位置,如果元素已經(jīng)存在,則插入到它的右邊位置。
函數(shù)原型如下:
bisect.insort_right(a, x, lo=0, hi=len(a), *, key=None)
其中,a
是一個(gè)有序列表,x
是要插入的元素,lo
和 hi
是查找范圍的左右邊界,key
是一個(gè)函數(shù),用于從列表中提取比較的鍵值。
示例:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 插入元素 4 bisect.insort_right(a, 4) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10] # 插入元素 6 bisect.insort_right(a, 6) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]
除此之外,insort_right
還可以簡寫為 insort
:
# 導(dǎo)入 bisect 庫 import bisect # 有序列表 a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10] # 插入元素 4 bisect.insort(a, 4) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10] # 插入元素 6 bisect.insort(a, 6) print(a) # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]
insort
函數(shù)的實(shí)質(zhì)是調(diào)用 bisect
函數(shù)獲取插入位置,然后調(diào)用 list.insert
函數(shù)將元素插入到該位置。
二分查找基礎(chǔ)實(shí)現(xiàn)
在 Python 中,我們可以使用 bisect
庫來實(shí)現(xiàn)二分查找,但其只能根據(jù)元素的值和元素之間的比較關(guān)系來查找元素的位置,如果要根據(jù)元素的其他屬性或其他關(guān)系來查找元素的位置,就需要自己實(shí)現(xiàn)二分查找了。
二分查找的基本模板如下:
def binary_search(nums, target): left, right = 0, len(nums) - 1 while left <= right: mid = (left + right) // 2 if nums[mid] == target: return mid elif nums[mid] < target: left = mid + 1 else: right = mid - 1 return -1
通過修改模板,我們可以根據(jù)更復(fù)雜的關(guān)系來查找元素。
示例:
852. 山脈數(shù)組的峰頂索引
符合下列屬性的數(shù)組arr
稱為 山脈數(shù)組 :
arr.length >= 3
- 存在
i
(0 < i < arr.length - 1
)使得:arr[0] < arr[1] < ... arr[i-1] < arr[i]
arr[i] > arr[i+1] > ... > arr[arr.length - 1]
給你由整數(shù)組成的山脈數(shù)組
arr
,返回任何滿足arr[0] < arr[1] < ... arr[i - 1] < arr[i] > arr[i + 1] > ... > arr[arr.length - 1]
的下標(biāo)i
。來源:力扣(LeetCode)
鏈接:https://leetcode.cn/problems/peak-index-in-a-mountain-array
解
class Solution: def peakIndexInMountainArray(self, arr: List[int]) -> int: n = len(arr) left, right, ans = 1, n - 2, 0 while left <= right: mid = (left + right) // 2 if arr[mid] > arr[mid + 1]: ans = mid right = mid - 1 else: left = mid + 1 return ans
到此這篇關(guān)于Python 二分查找:bisect庫的使用的文章就介紹到這了,更多相關(guān)Python bisect庫使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python優(yōu)雅實(shí)現(xiàn)二分查找的示例詳解
- 使用Python實(shí)現(xiàn)二分法查找的示例
- Python實(shí)現(xiàn)二分法查找及優(yōu)化的示例詳解
- Python算法練習(xí)之二分查找算法的實(shí)現(xiàn)
- 詳解Python查找算法的實(shí)現(xiàn)(線性,二分,分塊,插值)
- Python語言實(shí)現(xiàn)二分法查找
- python二分法查找函數(shù)底值
- python二分法查找實(shí)例代碼
- python中二分查找法的實(shí)現(xiàn)方法
- python實(shí)現(xiàn)二分查找算法
- python二分查找搜索算法的多種實(shí)現(xiàn)方法
相關(guān)文章
python 定時(shí)任務(wù)去檢測服務(wù)器端口是否通的實(shí)例
今天小編就為大家分享一篇python 定時(shí)任務(wù)去檢測服務(wù)器端口是否通的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01Python 刪除整個(gè)文本中的空格,并實(shí)現(xiàn)按行顯示
今天小編就為大家分享一篇Python 刪除整個(gè)文本中的空格,并實(shí)現(xiàn)按行顯示,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07python?tornado協(xié)程調(diào)度原理示例解析
這篇文章主要為大家介紹了python?tornado協(xié)程調(diào)度原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09np.where()[0] 和 np.where()[1]的具體使用
這篇文章主要介紹了np.where()[0] 和 np.where()[1]的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03python+openCV利用攝像頭實(shí)現(xiàn)人員活動(dòng)檢測
這篇文章主要為大家詳細(xì)介紹了python+openCV利用攝像頭實(shí)現(xiàn)人員活動(dòng)檢測,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06基于Python編寫一個(gè)計(jì)算器程序,實(shí)現(xiàn)簡單的加減乘除和取余二元運(yùn)算
這篇文章主要介紹了基于Python編寫一個(gè)計(jì)算器程序,實(shí)現(xiàn)簡單的加減乘除和取余二元運(yùn)算,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08詳解Python計(jì)算機(jī)視覺 圖像扭曲(仿射扭曲)
這篇文章主要介紹了Python計(jì)算機(jī)視覺 圖像扭曲(仿射扭曲),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Python實(shí)現(xiàn)替換文件中指定內(nèi)容的方法
這篇文章主要介紹了Python實(shí)現(xiàn)替換文件中指定內(nèi)容的方法,涉及Python文件讀寫、字符串替換等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03python中的selenium安裝的步驟(瀏覽器自動(dòng)化測試框架)
這篇文章主要介紹了python中的selenium安裝的步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03