欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實現(xiàn)在某個數(shù)組中查找一個值的算法示例

 更新時間:2018年06月27日 09:27:12   作者:bojdoog  
今天小編就為大家分享一篇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ù)組中查找一個值的算法示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

最新評論