温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么使用Python实现在某个数组中查找一个值的算法

发布时间:2021-04-12 13:54:56 来源:亿速云 阅读:778 作者:小新 栏目:开发技术

这篇文章主要介绍了怎么使用Python实现在某个数组中查找一个值的算法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

第一种算法思路:

第一步:随机出来一个数组的下标

第二步:判断下标对应的值是否等于被查找的值,是的话终止,已找到,否的话转第三步。

第三步:判断是否随机完数组的所有下标,是的话终止,没找到,否的话转第一步。

代码如下:

#本程序的功能是在字典中查找存在某个值 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:    #判断是否随机到了字典中的所有值,来决定是否接着循环   print 'no'   break

第二种算法思路:

线性查找法,即在数组中顺序的查找key值,找到就终止,没找到的话,一直查找到数组的末尾。

代码如下:

# -*- 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实现递归的二分查找算法 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)

对于算法的代码实现还有待优化,对于上述三种算法的运行时间,因本人才疏学浅,还没有具体分析。

感谢你能够认真阅读完这篇文章,希望小编分享的“怎么使用Python实现在某个数组中查找一个值的算法”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI