Python中的查找算法代碼實例
一. 順序查找
條件:無序或有序隊列。
原理:按順序比較每個元素,直到找到關鍵字為止。
時間復雜度: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ù)組的中間元素開始,如果中間元素正好是要查找的元素,則搜素過程結束;
如果某一特定元素大于或者小于中間元素,則在數(shù)組大于或小于中間元素的那一半中查找,而且跟開始一樣從中間元素開始比較。
如果在某一步驟數(shù)組為空,則代表找不到。
這種搜索算法每一次比較都使搜索范圍縮小一半。
時間復雜度: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))三. 插值查找
應用: 根據(jù)關鍵字的分布估計被查元素的位置,能更精確定位到被查找元素的位置,但應用有限
公式:mid = low + (key - low) / (a[high] - a[low]) * (high - low)
對于數(shù)據(jù)量較大,關鍵字分布比較均勻的查找表來說,采用插值查找, 速度較快
關鍵字分布不均勻的情況下,該方法不一定比折半查找要好
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)到此這篇關于Python中的查找算法代碼實例的文章就介紹到這了,更多相關Python查找算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python flask中動態(tài)URL規(guī)則詳解
今天小編就為大家分享一篇python flask中動態(tài)URL規(guī)則詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Python 字節(jié)流,字符串,十六進制相互轉(zhuǎn)換實例(binascii,bytes)
這篇文章主要介紹了Python 字節(jié)流,字符串,十六進制相互轉(zhuǎn)換實例(binascii,bytes),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
淺談python中np.array的shape( ,)與( ,1)的區(qū)別
今天小編就為大家分享一篇python中np.array的shape ( ,)與( ,1)的區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06

