Python實現(xiàn)在某個數(shù)組中查找一個值的算法示例
第一種算法思路:
第一步:隨機出來一個數(shù)組的下標
第二步:判斷下標對應的值是否等于被查找的值,是的話終止,已找到,否的話轉第三步。
第三步:判斷是否隨機完數(shù)組的所有下標,是的話終止,沒找到,否的話轉第一步。
代碼如下:
#本程序的功能是在字典中查找存在某個值 import random di = {'a':1,'b':2,'c':3,'d':4,'e':5,'f':6} key = 2 di1 = {} while True: tmp = random.choice(di.keys()) #隨機 if di[tmp] == key: print 'ok' #已找到key值 break di1.update({tmp:di[tmp]}) #更新字典di1 if di1 == di: #判斷是否隨機到了字典中的所有值,來決定是否接著循環(huán) print 'no' break
第二種算法思路:
線性查找法,即在數(shù)組中順序的查找key值,找到就終止,沒找到的話,一直查找到數(shù)組的末尾。
代碼如下:
# -*- encoding:utf-8 -*- li = [1,2,3,4,5,6] key = 90 i = len(li)-1 while i >= 0: if li[i] == key: print '在li[%d]的處找到key值' % i break i -= 1 else: print '沒找到'
第三種算法思路:
實際上是遞歸的二分查找算法,代碼如下:
#python實現(xiàn)遞歸的二分查找算法 li = [1,2,3,4,5,6,7] def find(li,key): if len(li)==1: if li[0] == key: return True return False m = len(li)/2 if find(li[:m],key) or find(li[m:],key): return True else: return False print find(li,8)
對于算法的代碼實現(xiàn)還有待優(yōu)化,對于上述三種算法的運行時間,因本人才疏學淺,還沒有具體分析。
以上這篇Python實現(xiàn)在某個數(shù)組中查找一個值的算法示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
python中subprocess批量執(zhí)行l(wèi)inux命令
本篇文章給大家詳細講述了python中使用subprocess批量執(zhí)行l(wèi)inux命令的方法,有興趣的朋友參考學習下。2018-04-04淺談Keras中shuffle和validation_split的順序
這篇文章主要介紹了淺談Keras中shuffle和validation_split的順序,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06python項目報錯:bs4.FeatureNotFound:?Couldn‘t?find?a?tree?bu
這篇文章主要給大家介紹了python項目報錯:bs4.FeatureNotFound:?Couldn‘t?find?a?tree?builder?with?the?features?you?requests的解決方式,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2022-09-09python 檢查數(shù)據(jù)中是否有缺失值,刪除缺失值的方式
今天小編就為大家分享一篇python 檢查數(shù)據(jù)中是否有缺失值,刪除缺失值的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12Python中DataFrame判斷兩列數(shù)據(jù)是否相等的方法
本文主要介紹了DataFrame判斷兩列數(shù)據(jù)是否相等的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04