python二分查找法

简介:

一、概述

1、条件
不是所有数据类型都可以应用二分查找法,他需要满足以下的条件:
是一个有序序列(索引数组),且是已经排好序的序列.
2、查找原理
在一个有序序列中查找一个指定的数,如果首先和这个序列的中间数相比如果相等就找到返回,如果比这个中间数小,即在序列左边找,如果比中间数大就从右边查找,直到找到或未找到返回.

二、python代码实现

知道了条件和原理后,其他任何一门语言都可实现,以下是python代码的简单实现.
参考代码

import math

L = [1,56,58,60,66,70,7,98,100,111,49999,99999]
count = 0     #定义统计查找次数
#查找是否在列表中
def bin_search(arg,num):
    global count
    begin = 0
    end = len(arg) -1    #最后一个索引
    mid = math.floor((end - begin)/2)  #获取中间数索引,math.floor用于获取向下取整
    mid_value = arg[mid]                 #中间数
    try:
        if mid_value == num:               #要找的数刚好是中间数
            count +=1
            ret = "%d在列表中,共查找了%d" %(num,count)
        elif mid_value > num:    #说明在左侧
            count += 1
            ret = bin_search(arg[:mid],num)  #从原列表的开始到中间索引为新查找的位置
        else:                      ##说明在右侧
            count += 1
            ret = bin_search(arg[mid+1:],num)        #从原列表的中间到最右(后)的位置
        return ret
    except:
        return "%d 不在列表中!" %num

查找66是否在列表中 并统计查找次数
print(bin_search(L,66))
如图:
python二分查找法

再来查找88时提示没有找到,如图:
print(bin_search(L,88))
python二分查找法

添加以下代码我们看看一个长度为100000的列表中查找L中的各元素各需要多少次

L1 = [ ]
for i in range(100000):   #生成100000长度的列表
    L1.append(i)

for num in L:
    print(bin_search(L1,num))
    count = 0

运行结果如下:
python二分查找法
请注意:在一个长度为100000的序列中找49999这个数,一次就找到了,只因为它是中间数.

总结:

通过二分查找法去查找一个数是否在列表中,要查找的数是中间数时,只要一次就能找到,最差的情况就是n/2 =0时,n为序列长度 但最后等于0时要么找到要么没有找到.不管怎么样比冒泡排序效率要高的多.不需要一个一个的元素比对.










本文转自 dyc2005 51CTO博客,原文链接:http://blog.51cto.com/dyc2005/2051124,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
算法 索引 Python
Python中如何实现二分查找?请提供代码示例。
Python中如何实现二分查找?请提供代码示例。
47 0
|
2月前
|
算法 数据挖掘 数据处理
搜索新境界:Python二分查找变种实战,精准定位数据不是梦!
【7月更文挑战第13天】二分查找算法以O(log n)效率在有序数组中查找数据。基础算法通过不断分割数组对比中间元素。Python实现变种包括:1) 查找目标值的第一个出现位置,找到后向左搜索;2) 查找目标值的最后一个出现位置,找到后向右搜索。这些变种在数据分析和索引构建等场景中极具价值,提升处理效率。
49 6
|
2月前
|
Python
二分查找变种大赏!Python 中那些让你效率翻倍的搜索绝技!
【7月更文挑战第12天】二分查找是高效搜索算法,适用于有序数组。基础原理是对比中间元素,按目标值大小在左右两侧递归查找。
26 4
|
1月前
|
Python
【Leetcode刷题Python】704. 二分查找
解决LeetCode "二分查找" 问题的Python实现代码。
11 0
|
1月前
|
算法 索引 Python
【Leetcode刷题Python】34. 在排序数组中查找元素的第一个和最后一个位置(二分查找)
解决LeetCode "在排序数组中查找元素的第一个和最后一个位置" 问题的方法。第一种方法是使用两次二分查找,首先找到目标值的最左边界,然后找到最右边界。第二种方法是利用Python的list.index()方法,先正序找到起始位置,再逆序找到结束位置,并给出了两种方法的Python实现代码。
43 0
|
2月前
|
算法 数据处理 开发者
超越传统:Python二分查找的变种策略,让搜索效率再上新台阶!
【7月更文挑战第11天】二分查找算法在有序数组中以O(log n)效率搜索元素。本文扩展了这一概念,介绍了3种Python变种:1) 查找第一个匹配值的位置,2) 找到最后一个匹配值,3) 在旋转有序数组中搜索。通过调整边界条件,这些变种增强了二分查找的适用性。代码示例展示了如何实现这些策略,以优化不同场景下的搜索效率。
17 0
|
4月前
|
算法 开发者 索引
深入理解Python中的二分查找与bisect模块
深入理解Python中的二分查找与bisect模块
|
4月前
|
机器学习/深度学习 存储 算法
Python排序——二分查找
Python排序——二分查找
42 0
|
4月前
|
Python
【python】二分查找
【python】二分查找
24 0
|
4月前
|
算法 索引 Python
如何实现二分查找算法? 要求:编写一个Python函数,输入一个有序列表和一个目标值,返回目标值在列表中的索引。如果目标值不在列表中,返回-1。
如何实现二分查找算法? 要求:编写一个Python函数,输入一个有序列表和一个目标值,返回目标值在列表中的索引。如果目标值不在列表中,返回-1。
60 0