时间:2021-05-22
第一种算法思路:
第一步:随机出来一个数组的下标
第二步:判断下标对应的值是否等于被查找的值,是的话终止,已找到,否的话转第三步。
第三步:判断是否随机完数组的所有下标,是的话终止,没找到,否的话转第一步。
代码如下:
#本程序的功能是在字典中查找存在某个值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实现在某个数组中查找一个值的算法示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Python3实现旋转数组的3种算法下面是Python3实现的旋转数组的3种算法。一、题目给定一个数组,将数组中的元素向右移动k个位置,其中k是非负数。例如:输
二分查找算法:简单的说,就是将一个数组先排序好,比如按照从小到大的顺序排列好,当给定一个数据,比如target,查找target在数组中的位置时,可以先找到数组
初级1.定义一个函数,获取某个数组中的最小值packagepractise;publicclassGetMin{publicstaticvoidgetMin(i
本文实例讲述了JS数组搜索之折半搜索实现方法。分享给大家供大家参考,具体如下:一.方法原理:当从一个给定的序列数组arr中,查找某个特定值value时,折半搜索
本文实例讲述了Python实现的旋转数组功能算法。分享给大家供大家参考,具体如下:一、题目给定一个数组,将数组中的元素向右移动k个位置,其中k是非负数。例1:输