Python算法练习之二分查找算法的实现

 更新时间:2022年06月16日 08:51:37   作者:小袁ITSuper  
二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。本文将介绍python如何实现二分查找算法,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下

1. 算法描述

二分法是一种效率比较高的搜索方法

回忆之前做过的猜数字的小游戏,预先给定一个小于100的正整数x,让你猜猜测过程中给予大小判断的提示,问你怎样快速地猜出来?

我们之前做的游戏给定的是10次机会,如果我们学会.二分查找法以后,不管数字是多少,最多只需要7次就能猜到数字。

2. 算法分析

1、必须是有序的序列。

2、对数据量大小有要求。

数据量太小不适合二分查找,与直接遍历相比效率提升不明显。

数据量太大也不适合用二分查找,因为数组需要连续的存储空间,若数据量太大,往往找不到存储如此大规模数据的连续内存空间。.

3. 算法思路

假设有一个有序列表如下:

请问数字11是否在此列表中,如果在它的索引值为多少?

4. 代码实现

纯算法实现

实现代码

arr_list = [5, 7, 11, 22, 27, 33, 39, 52, 58]
# 需要查找的数字
seek_number = 11
# 保存一共查找了几次
count = 0
# 列表左侧索引
left = 0
# 列表右侧索引
right = len(arr_list) - 1
# 当左侧索引小于等于右侧索引时
while left <= right:
    # 取中间的索引位置
    middle = (left + right) // 2
    # 查找次数进行累加
    count += 1
    # 如果查找的数字大于中间位置的数字时
    if seek_number > arr_list[middle]:
        # 左侧索引为中间位置索引+1
        left = middle + 1
    # 如果查找的数字小于中间位置的数字时
    elif seek_number < arr_list[middle]:
        # 右侧索引为中间位置索引-1
        right = middle - 1
    # 如果等于中间索引数据
    else:
        print('数字:%s找到了,索引值为:%s' % (seek_number, middle))
        break
else:
    print("数字%s 没有找到" % seek_number)
print("一共用了:%s次查找" % count)

运行结果

递归法实现

在循环中定义了一个变量count,如果第一次循环后count没有变化,就说明输入的是有序序列,这时我们直接return退出循环,这时候的时间复杂度为O(n)

实现代码

arr_list = [5, 7, 11, 22, 27, 33, 39, 52, 58]

def binary_search(seek_number, left, right):
    if left <= right:
        middle = (left + right) // 2
        if seek_number < arr_list[middle]:
            right = middle - 1
        elif seek_number > arr_list[middle]:
            left = middle + 1
        else:
            return middle
        # 进行递归调用
        return binary_search(seek_number, left, right)
    # 当左侧索引大于右侧索引时,说明没有找到
    else:
        return -1

# 查找的数字
seek_number = 11
# 列表左侧索引
left = 0
# 列表右侧索引
right = len(arr_list) - 1
print("查找的数字:%s,索引为:%s" % (seek_number, binary_search(seek_number, left, right)))

运行结果

以上就是Python算法练习之二分查找算法的实现的详细内容,更多关于Python二分查找算法的资料请关注脚本之家其它相关文章!

相关文章

  • Python递归求出列表(包括列表中的子列表)的最大值实例

    Python递归求出列表(包括列表中的子列表)的最大值实例

    今天小编就为大家分享一篇Python递归求出列表(包括列表中的子列表)的最大值实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • Selenium自动化测试实现窗口切换

    Selenium自动化测试实现窗口切换

    这篇文章主要介绍了Selenium自动化测试实现窗口切换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Python检测QQ在线状态的方法

    Python检测QQ在线状态的方法

    这篇文章主要介绍了Python检测QQ在线状态的方法,涉及Python通过第三方平台检测QQ在线状态的技巧,非常简单实用,需要的朋友可以参考下
    2015-05-05
  • Python容器类型之列表/字典/元组/集合方式

    Python容器类型之列表/字典/元组/集合方式

    这篇文章主要介绍了Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • 使用Python编写一个粘贴python源代码就能运行的工具

    使用Python编写一个粘贴python源代码就能运行的工具

    以下是一个使用wxPython模块创建带有Memo(文本输入框)和保存按钮的GUI程序示例,点击保存按钮后将Memo内容保存到指定路径下的文件,并提供运行按钮以执行指定的Python脚本,需要的朋友可以参考下
    2025-04-04
  • Python通过cron或schedule实现爬虫的自动定时运行

    Python通过cron或schedule实现爬虫的自动定时运行

    自动定时运行爬虫是很多数据采集项目的基本需求,通过 Python 实现定时任务,可以保证数据采集的高效和持续性,本文将带大家了解如何在 Python 中使用 cron 和 schedule 来实现爬虫的自动定时运行,需要的朋友可以参考下
    2024-12-12
  • Pytorch 实现数据集自定义读取

    Pytorch 实现数据集自定义读取

    今天小编就为大家分享一篇Pytorch 实现数据集自定义读取,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • python持久化存储文件操作方法

    python持久化存储文件操作方法

    本文给大家分享python持久化存储文件操作方法,给大家讲解存储文件的重要性,指针的基本概念及关闭文件的方法,介绍文件的创建和删除技巧,感兴趣的朋友一起看看吧
    2021-06-06
  • Python Pandas 箱线图的实现

    Python Pandas 箱线图的实现

    这篇文章主要介绍了Python Pandas 箱线图的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • python 解压pkl文件的方法

    python 解压pkl文件的方法

    今天小编就为大家分享一篇python 解压pkl文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10

最新评论