国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現在某個數組中查找一個值的算法示例

2020-02-15 22:03:50
字體:
來源:轉載
供稿:網友

第一種算法思路:

第一步:隨機出來一個數組的下標

第二步:判斷下標對應的值是否等于被查找的值,是的話終止,已找到,否的話轉第三步。

第三步:判斷是否隨機完數組的所有下標,是的話終止,沒找到,否的話轉第一步。

代碼如下:

#本程序的功能是在字典中查找存在某個值import randomdi = {'a':1,'b':2,'c':3,'d':4,'e':5,'f':6}key = 2di1 = {}while True: tmp = random.choice(di.keys()) #隨機 if di[tmp] == key:  print 'ok'    #已找到key值  break di1.update({tmp:di[tmp]}) #更新字典di1 if di1 == di:    #判斷是否隨機到了字典中的所有值,來決定是否接著循環  print 'no'  break

第二種算法思路:

線性查找法,即在數組中順序的查找key值,找到就終止,沒找到的話,一直查找到數組的末尾。

代碼如下:

# -*- encoding:utf-8 -*-li = [1,2,3,4,5,6]key = 90i = len(li)-1while i >= 0: if li[i] == key:  print '在li[%d]的處找到key值' % i  break i -= 1else: print '沒找到'

第三種算法思路:

實際上是遞歸的二分查找算法,代碼如下:

#python實現遞歸的二分查找算法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 Falseprint find(li,8)

對于算法的代碼實現還有待優化,對于上述三種算法的運行時間,因本人才疏學淺,還沒有具體分析。

以上這篇Python實現在某個數組中查找一個值的算法示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 苏尼特左旗| 遂平县| 礼泉县| 阿坝| 页游| 海口市| 虎林市| 东宁县| 平邑县| 合水县| 咸丰县| 离岛区| 沙田区| 德州市| 高平市| 昌吉市| 都兰县| 屏东县| 兴海县| 海口市| 民勤县| 淳安县| 南投县| 苏尼特左旗| 和平县| 涿州市| 濮阳县| 巴南区| 南川市| 灵宝市| 新巴尔虎左旗| 安图县| 承德县| 商南县| 罗田县| 汽车| 额尔古纳市| 五家渠市| 无锡市| 临夏县| 且末县|