当前位置:首页 > 科技  > 软件

优雅实现Python二分查找:探索高效的有序数据搜索策略

来源: 责编: 时间:2023-09-18 21:40:56 374观看
导读二分查找是一种高效的搜索算法,用于在有序数组中查找特定元素。它的思想是将查找范围逐渐缩小一半,直到找到目标元素或确定目标元素不存在。本文将介绍二分查找的基本原理,并通过Python代码进行详细讲解。一、原理二分查

二分查找是一种高效的搜索算法,用于在有序数组中查找特定元素。它的思想是将查找范围逐渐缩小一半,直到找到目标元素或确定目标元素不存在。本文将介绍二分查找的基本原理,并通过Python代码进行详细讲解。7hT28资讯网——每日最新资讯28at.com

7hT28资讯网——每日最新资讯28at.com

一、原理

二分查找的原理非常简单,基本步骤如下:7hT28资讯网——每日最新资讯28at.com

(1) 确定查找范围的起始点和终点。通常情况下,起始点为数组的第一个元素,终点为数组的最后一个元素。7hT28资讯网——每日最新资讯28at.com

(2) 计算中间点的位置,并取得中间点的值。7hT28资讯网——每日最新资讯28at.com

(3) 将中间点的值与目标值进行比较。7hT28资讯网——每日最新资讯28at.com

  • 如果中间点的值等于目标值,说明已经找到了目标元素,查找成功。
  • 如果中间点的值大于目标值,说明目标元素可能在左半部分,将查找范围缩小到左半部分。
  • 如果中间点的值小于目标值,说明目标元素可能在右半部分,将查找范围缩小到右半部分。

(4) 重复步骤2和步骤3,直到找到目标元素或确定目标元素不存在。7hT28资讯网——每日最新资讯28at.com

二、示例代码

下面是使用Python实现二分查找算法的示例代码:7hT28资讯网——每日最新资讯28at.com

def binary_search(arr, target):    """    二分查找算法    :param arr: 有序数组    :param target: 目标元素    :return: 目标元素的索引,如果不存在则返回-1    """    low = 0  # 查找范围的起始点    high = len(arr) - 1  # 查找范围的终点    while low <= high:        mid = (low + high) // 2  # 计算中间点的位置        guess = arr[mid]  # 获取中间点的值        if guess == target:  # 如果中间点的值等于目标值,查找成功            return mid        elif guess > target:  # 如果中间点的值大于目标值,说明目标元素可能在左半部分            high = mid - 1  # 将查找范围缩小到左半部分        else:  # 如果中间点的值小于目标值,说明目标元素可能在右半部分            low = mid + 1  # 将查找范围缩小到右半部分    return -1  # 目标元素不存在

这段代码定义了一个 binary_search 函数,接受一个有序数组 arr 和目标值 target 作为参数。函数使用 low 和 high 来表示查找范围的起始点和终点,初始时起始点为数组的第一个元素,终点为数组的最后一个元素。在每次循环中,根据中间点的值和目标值的大小关系,更新查找范围的起始点和终点,以逐渐缩小查找范围。如果找到目标元素,则返回目标元素的索引;如果目标元素不存在于数组中,则返回-1。7hT28资讯网——每日最新资讯28at.com

三、使用示例

接下来,我们将使用示例来演示二分查找的使用方法。假设有一个有序数组 [1, 3, 5, 7, 9, 11, 13, 15, 17, 19],我们要查找元素 11 的索引。我们可以使用 binary_search 函数来进行查找:7hT28资讯网——每日最新资讯28at.com

arr = [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]target = 11result = binary_search(arr, target)if result != -1:    print("目标元素的索引为:", result)else:    print("目标元素不存在")

输出结果为:7hT28资讯网——每日最新资讯28at.com

目标元素的索引为: 5

说明目标元素 11 存在于数组中,并且其索引为 5。7hT28资讯网——每日最新资讯28at.com

四、总结

通过本文的讲解,我们了解了二分查找的基本原理和使用方法。二分查找是一种高效的搜索算法,适用于有序数组中查找目标元素。通过将查找范围逐渐缩小一半,可以快速定位目标元素。在实际应用中,二分查找常被用于搜索和排序等领域。7hT28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-10438-0.html优雅实现Python二分查找:探索高效的有序数据搜索策略

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java开发必安装插件-Maven Helper

下一篇: Go语言进化之路:泛型的崛起与复用的新篇章

标签:
  • 热门焦点
  • 6月iOS设备性能榜:M2稳居榜首 A系列只能等一手3nm来救

    没有新品发布,自然iOS设备性能榜的上榜设备就没有什么更替,仅仅只有跑分变化而产生的排名变动,毕竟苹果新品的发布节奏就是这样的,一年下来也就几个移动端新品,不会像安卓厂商,一
  • iPhone卖不动了!苹果股价创年内最大日跌幅:市值一夜蒸发万亿元

    8月5日消息,今天凌晨美股三大指数高开低走集体收跌,道指跌0.41%;纳指跌0.36%;标普500指数跌0.52%。热门科技股也都变化极大,其中苹果报181.99美元,跌4.8%,创
  • 把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 虚拟键盘 API 的妙用

    你是否在遇到过这样的问题:移动设备上有一个固定元素,当激活虚拟键盘时,该元素被隐藏在了键盘下方?多年来,这一直是 Web 上的默认行为,在本文中,我们将探讨这个问题、为什么会发生
  • “又被陈思诚骗了”

    作者|张思齐 出品|众面(ID:ZhongMian_ZM)如今的国产悬疑电影,成了陈思诚的天下。最近大爆电影《消失的她》票房突破30亿断层夺魁暑期档,陈思诚再度风头无两。你可以说陈思诚的
  • 小米MIX Fold 3下月亮相:今年唯一无短板的全能折叠屏

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都有新的进展,其中荣耀、三星都已陆续发布了最新的折叠屏旗舰,尤其号荣耀Magi
  • 支持aptX Lossless无损传输 iQOO TWS 1赛道版发布限时优惠价369元

    2023年7月4日,“无损音质,声动人心”iQOO TWS 1正式发布,支持aptX Lossless无损传输,限时优惠价369元。iQOO TWS 1耳机率先支持端到端aptX Lossless无
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top