有关在某个数组中查找一个值的算法(Python实现)

本文介绍了在Python中查找数组中特定值的三种算法:随机查找、线性查找和递归二分查找。每种算法都有详细的步骤说明,并提供了相应的代码实现。虽然算法已实现,但作者指出运行时间分析尚未进行。
摘要由CSDN通过智能技术生成

第一种算法思路:

第一步:随机出来一个数组的下标
第二步:判断下标对应的值是否等于被查找的值,是的话终止,已找到,否的话转第三步。
第三步:判断是否随机完数组的所有下标,是的话终止,没找到,否的话转第一步。
代码如下:

#本程序的功能是在字典中查找存在某个值
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] ==
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值