Python中的查找算法代碼實例
一. 順序查找
條件:無序或有序隊列。
原理:按順序比較每個元素,直到找到關(guān)鍵字為止。
時間復(fù)雜度:O(n)
def sequential_search(lis, key): length = len(lis) for i in range(length): print(lis[i], key) if lis[i] == key: return i return False if __name__ == '__main__': LIST = [1, 5, 8, 123, 22, 54, 7, 99, 300, 222] result = sequential_search(LIST, 123) print(result)
二. 二分查找
條件:有序數(shù)組
原理:查找過程從數(shù)組的中間元素開始,如果中間元素正好是要查找的元素,則搜素過程結(jié)束;
如果某一特定元素大于或者小于中間元素,則在數(shù)組大于或小于中間元素的那一半中查找,而且跟開始一樣從中間元素開始比較。
如果在某一步驟數(shù)組為空,則代表找不到。
這種搜索算法每一次比較都使搜索范圍縮小一半。
時間復(fù)雜度:O(logn)
lst = [11, 22, 33, 44, 55, 66, 77, 88, 99, 123, 234, 345, 456, 567, 678, 789] def func(alist, data): first = 0 last = len(alist) - 1 while first <= last: mid = (last + first) // 2 if alist[mid] > data: last = mid - 1 elif alist[mid] < data: first = mid + 1 else: return mid return -1 print(func(lst, 678))
三. 插值查找
應(yīng)用: 根據(jù)關(guān)鍵字的分布估計被查元素的位置,能更精確定位到被查找元素的位置,但應(yīng)用有限
公式:mid = low + (key - low) / (a[high] - a[low]) * (high - low)
對于數(shù)據(jù)量較大,關(guān)鍵字分布比較均勻的查找表來說,采用插值查找, 速度較快
關(guān)鍵字分布不均勻的情況下,該方法不一定比折半查找要好
def binary_search(lis, key): low = 0 high = len(lis) - 1 while low < high: mid = low + int((high - low) * (key - lis[low]) / (lis[high] - lis[low])) if key < lis[mid]: high = mid - 1 elif key > lis[mid]: low = mid + 1 else: return mid return False LIST = [1, 5, 7, 8, 22, 54, 99, 123, 200, 222, 444] result = binary_search(LIST, 99) print(result)
到此這篇關(guān)于Python中的查找算法代碼實例的文章就介紹到這了,更多相關(guān)Python查找算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python flask中動態(tài)URL規(guī)則詳解
今天小編就為大家分享一篇python flask中動態(tài)URL規(guī)則詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11Python 字節(jié)流,字符串,十六進(jìn)制相互轉(zhuǎn)換實例(binascii,bytes)
這篇文章主要介紹了Python 字節(jié)流,字符串,十六進(jìn)制相互轉(zhuǎn)換實例(binascii,bytes),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-055款最強(qiáng)且免費的Python IDE小結(jié)
開發(fā)工具在日常代碼編寫過程中起著至關(guān)重要的作用,一款優(yōu)秀的開發(fā)工具,不僅可以盡可能的減少你在配置方面耗費的精力,本文主要介紹了5種,感興趣的可以了解一下2021-07-07淺談python中np.array的shape( ,)與( ,1)的區(qū)別
今天小編就為大家分享一篇python中np.array的shape ( ,)與( ,1)的區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06