python实现二分查找算法
作者:nfzhlk 时间:2023-04-04 12:34:40
二分查找算法:简单的说,就是将一个数组先排序好,比如按照从小到大的顺序排列好,当给定一个数据,比如target,查找target在数组中的位置时,可以先找到数组中间的数array[middle]和target进行比较,当它比target小时,那么target一定是在数组的右边,反之,则target在数组的左边,比如它比target小,则下次就可以只比较[middle+1, end]的数,继续使用二分法,将它一分为二,直到找到target这个数返回或者数组全部遍历完成(target不在数组中)
优点:效率高,时间复杂度为O(logN);
缺点:数据要是有序的,顺序存储。
python的代码实现如下:
#!/usr/bin/python env
# -*- coding:utf-8 -*-
def half_search(array,target):
low = 0
high = len(array) - 1
while low < high:
mid = (low + high)/2
if array[mid] > target:
high = mid - 1
elif array[mid] < target:
low = mid + 1
elif array[mid] == target:
print 'I find it! It is in the position of:',mid
return mid
else:
print "please contact the coder!"
return -1
if __name__ == "__main__":
array = [1, 2, 2, 4, 4, 5]
运行结果如下:
I find it! It is in the position of: 4
4
-1
I find it! It is in the position of: 0
0
-1
来源:http://blog.csdn.net/nfzhlk/article/details/78047386
标签:python,二分查找
0
投稿
猜你喜欢
python基础教程之元组操作使用详解
2023-11-29 01:18:52
Tensorflow获取张量Tensor的具体维数实例
2021-12-24 20:25:10
python执行CMD指令,并获取返回的方法
2021-10-19 02:52:40
python实现合并两个数组的方法
2022-05-30 21:40:11
你知道怎么在淘宝里进行投诉吗?
2008-06-04 12:00:00
OpenCV-PS扩散毛玻璃效果的实现代码
2022-03-17 22:45:52
centos7.3 安装mysql5.7.18的详细教程
2024-01-12 18:57:00
Python3利用Dlib19.7实现摄像头人脸识别的方法
2022-08-08 06:41:22
Python GUI编程 文本弹窗的实例
2022-08-24 02:07:48
解决MySQL5.7安装后没有data文件夹无法登录的问题
2024-01-14 21:39:50
linux下指定mysql数据库服务器主从同步的配置实例
2024-01-20 01:16:05
python实现图片批量剪切示例
2021-11-18 13:04:38
语言化H1标签
2008-01-11 13:54:00
mysql 5.7.18 免安装版window配置方法
2024-01-14 15:03:45
讲解Access数据库中数据表的自动重新联接
2008-11-28 16:29:00
Python命令行参数argv和argparse该如何使用
2022-04-05 01:38:52
重新认识视觉设计
2009-09-08 12:46:00
判断sql语句执行是否成功
2008-07-05 12:22:00
Python3数据库操作包pymysql的操作方法
2024-01-28 20:01:34
探讨各种PHP字符串函数的总结分析
2024-05-11 10:02:16