Python真题案例之二分法查找详解
作者:酷尔。 发布时间:2023-09-23 01:39:07
写在前面的话🪐
学了Python一些基础知识之后,相信大家对Python使用方法有了一定的感悟,想要追求深层次的东西还要细细的学、慢慢的学。Python基础教程更新到今天语法基础算是完了,本专栏后续会对面向对象模块更新。在进行面向对象更新之前呢会有一步小插曲就是Python 百炼成钢系列。主要的作用呢就是使用Python刷一刷算法题,使自己的基础更加稳固。在更新期间收到了广大小伙伴的喜爱,博主的知识水平也有所提升。下面呢咱们进入正题讲解今天咱们要学习的二分查找法。
问题描述🪐
在学习一门语言的时候,咱们做的最多的一件事就是对数据进行增删改查,而对于增删改查操作中最常做的就是查,因为一个软件主要的作用就是对亲爱的用户进行信息展示,只有少部分管理员或者拥有权限的用户才可以操作数据。比如在链表、数组中查找东西,咱们需要从头开始遍历,挨个检索。数据量庞大的时候会很令人头疼。今天介绍的二分法查找(或称折半查找) 主要是针对有序数列(也就是说数据要先排序)。然后每次取中值进行比较,依次折半缩小查找范围。
原理分析🪐
1.实现步骤
1)确定该区间的中间位置K,在数组两边加上区间左右边界l,r
2)将查找的值T与array[k]比较。若相等,查找成功返回此位置;否则确定新的查找区域,继续二分查找。
区域确定如下:
每一次查找与中间值比较,判断是否查找成功,不成功当前查找区间将缩小一半。 视情况重新定左右边界与中间索引k
时间复杂度为:O(log2n)。
2.图解
图片源于网络
参考代码🪐
这里在写代码的时候对比了系统内置查找关键字in与二分法查找的运行效果 打印结果如下:
由此可见Python底层的查找算法还是超级快的。使用起来也很方便
二分查找在本次实验中输在了需要对列表进行排序上
对于有序量大的数据就可以体现出来二分查找的优势了
import time,math,random
#计时器(使用的是函数装饰器前面说函数的时候提到过)
def timeT(func):
def wapper(*s):
start=time.perf_counter()
judge=func(*s)
end=time.perf_counter()
return judge,start-end
return wapper
# 使用内置查找方法
@timeT
def serch1(lists,e):
return e in lists
# 二分法
@ timeT
def serch2(lists,e):
flag=False
lists=sorted(lists)
# print(lists)
# 左游标
lo=0
# 右游标
ma=len(lists)-1
# 中间位置
mid=len(lists)//2
# 没有在列表内
if lists[ma]<e:
return False
if lists[lo]>e:
return False
# 依次缩小左右游标,直到lo>ma
while lo<=ma:
if lists[mid]>e:
ma=mid
mid=(lo+ma)//2
elif lists[mid]<e:
lo=mid
mid=(lo+ma)//2
else:
#标记位,True代表查到了
flag=True
break
return flag
def main():
#生成一个含有10000个元素的列表
numarr=[x for x in range(10000)]
#打乱列表顺序
random.shuffle(numarr)
print(*serch1(numarr,23))
print(*serch2(numarr,223))
print(223 in numarr)
# print(numarr)
if __name__=="__main__":
main()
来源:https://blog.csdn.net/apple_51931783/article/details/123208914


猜你喜欢
- Django开发过程中如果数据库变动过多导致migrations的文件越来越多,管理起来很不方便, 幸运的是Django提供了一种方式可以是
- 本文主讲Python中Numpy数组的类型、全0全1数组的生成、随机数组、数组操作、矩阵的简单运算、矩阵的数学运算。尽管可以用python中
- 一基础理解: var e = document.getElementById("selectId");e. option
- 这里所谓的复杂表单,是指表单中包含多种不同的输入类型,比如下拉列表框、单行文本、多行文本、数值等。在经常需要更换这类表单的场合,需要有一个表
- 一、“无”的哲学佛家讲究“因果报应”,有果必有应。此段看似与主题没有血缘关系,实际讲的是“因”。我个人比较喜欢老子的道家思想,并喜欢以其思想
- 1.数组上的迭代NumPy 包含一个迭代器对象numpy.nditer。它是一个有效的多维迭代器对象,可以用于在数组上进行迭代。数组的每个元
- 写在前面这篇文章推荐一个由Golang编写的一个命令行工具——Glow,这个CLI工具可以在命令行读
- 本文实例为大家分享了python3音乐播放器的关键代码,供大家参考,具体内容如下from tkinter import *from trac
- python / 和 % 和 //(地板除)用于对数据进行除法运算。python中 // 和 / 和 %简介python中与除法相关的三个运
- 如果你从来没有使用过Python,我强烈建议你阅读Python introduction,因为你需要知道基本的语法和类型。包管理Python
- 据 Python 软件基金会消息,Python Packaging Authority 和 pip 团队于北美时间11月30日宣布发布 pi
- 1.正态分布简介正态分布(normal distribtution)又叫做高斯分布(Gaussian distribution),是一个非常
- 01-初心缘由最近在研究语音识别方向,看了很多的语音识别的资料和文章,了解了一下语音识别的前世今生,其中包含了很多算法的演变,目前来说最流行
- 有些 SQL Server 2000 Personal Edition 实例和 SQL Server 2000 Desktop Engine
- 一、变量1.变量Python 中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。在 Python 中,变量就是变
- tkinter 是 Python 的标准 GUI 库。Python 使用 tkinter 可以快速的创建 GUI 应用程序。由于 tkint
- Mysql Table doesn't exist问题程序连接Mysql的时候总是提示表不存在,Table 'xx.QRTZ
- 运用webbrowser库中的一个函数实现自动打开浏览器:webbrowser.open(http://blog.csdn.net/ares
- 装饰器本质是一个接受参数为函数的函数。作用:为一个已经实现的方法添加额外的通用功能,比如日志记录、运行计时等。举例1.不带参数的装饰器,不用
- 经常在前端面试或是和其他同行沟通是,在谈到构造在JS定义构造函数的方法是最好使用原型的方式:将方法定义到构造方法的prototype上,这样