python输入列表二分法_python使用二分法实现在一个有序列表中查找指定的元素

二分法是一种快速查找的方法,时间复杂度低,逻辑简单易懂,总的来说就是不断的除以2除以2...

例如需要查找有序list里面的某个关键字key的位置,那么首先确认list的中位数mid,下面分为三种情况:

如果 list[mid] < key,说明key 在中位数的 右边;

如果 list[mid] > key,说明key 在中位数的 左边;

如果 list[mid] = key,说明key 在中位数的中间;

范围每次缩小一半,写个while的死循环知道找到为止。

二分法查找非常快且非常常用,但是唯一要求是要求数组是有序的

代码如下

1 #!/usr/bin/python2.7

2 #-*- coding: utf-8 -*-

3

4 defBinarySearch(lista, key):5 #记录数组的最高位和最低位

6 min =07 max = len(lista) - 1

8

9 if key inlista:10 #建立一个死循环,直到找到key

11 whileTrue:12 #得到中位数

13 mid = (min + max) / 2

14 #key在数组左边

15 if lista[mid] >key:16 max = mid - 1

17 #key在数组右边

18 elif lista[mid]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值