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

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

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

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

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

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

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

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

代码如下

 

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