Python中如何实现二分查找
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇文章为大家展示了Python中如何实现二分查找,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。二分查找是一个用的非常多的查找算法,目的是从一个列表list里
千家信息网最后更新 2025年12月03日Python中如何实现二分查找
本篇文章为大家展示了Python中如何实现二分查找,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
二分查找是一个用的非常多的查找算法,目的是从一个列表list里面,找到一个你想要的数,记做目标数据,返回这个数的索引,比如[5, 12, 3], 想找到12在哪,然后答案应该是1。直接的方法是从头开始,一个个比较,如果相等就返回,先拿5和12比, 不相等就继续下一个,12 = 12, 所以返回1,但是如果这个列表很大, 这样查找起来就比较慢,时间复杂度是O(n),而二分查找是一个比较高效的查找方法,数学里面学过二分法,我觉得道理是类似的。二分查找的时间复杂度是O(logn)。
二分查找的一般过程为先找到数组的中间数据,然后对比目标数据和中间数据,如果相等则返回中间数据,如果目标数据大于中间数据,则继续在列表的右边按照相同方法去寻找。否则在左边寻找;这里要注意的是,查找过程中的列表是经过排序以后的,所以这里比较的时候才会按大小去搜索。
下面是用Python实现二分查找的一个栗子
def binary_search(array, query_value):
low, high = 0, len(array) - 1
while low <= high:
mid = low + (high - low) // 2
mid_val = array[mid]
if mid_val == query_value:
return mid
elif mid_val < query_value:
low = mid + 1
else:
high = mid - 1
return None
def main():
array_1 = [1, 10, 20, 30, 180]
print binary_search(array_1, 20)
print "- * - " * 5
array_2 = [2, 1, 3, 3, 5, 4, 1, 6]
sorted_array = sorted(array_2)
print "sorted_array : ", sorted_array
print(binary_search(sorted_array, 5))
if __name__ == "__main__":
main()
上述内容就是Python中如何实现二分查找,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
数据
方法
目标
复杂
内容
复杂度
技能
时间
知识
过程
很大
相同
简明
简明扼要
二分法
右边
就是
数学
数组
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库系统阶段冗余性
签订网络安全书
新郑服务器救援电话
网络安全法法条测试答案
高校的网络安全教育现状
计算机网络技术及应用简介
亲爱的热爱的为什么是网络安全
远程id怎么获取数据库
成都系统集成软件开发
数据库安全性包括几层
山西网络安全部门
信息与网络安全概括
长沙网络安全培训
求职上海网络技术
我的世界服务器外面的图片怎么改
数据库可视化设计工具
保定天气预报软件开发
泰安智能养老软件开发公司
视觉测量软件开发
新氧科技和互联网医院
数据库怎么打开查询分析器
陕西学校卫星授时服务器云主机
代练炫舞服务器
铜仁天气预报软件开发
安全级别 数据库a1级
河北嵌入式软件开发哪家好
国产数据库概念股龙头股
db数据库怎么设置自动增长
哈工程研究生院网络安全梦想
软件开发移动方向什么意思