详解二分查找算法原理与使用方法

二分查找算法,又称折半查找算法,是一种高效的查找算法。它的基本思想是将查找区间从中间进行分割,再根据目标值与中间值的大小关系选择下一次查找的区间,从而逐步缩小查找范围,直到找到目标值或无法分割为止。这种算法的时间复杂度是 $O(\log n)$,非常适合于大型数据集的查找。

作用

二分查找算法适用于有序数组中的查找操作,可以快速定位数组中特定元素的位置,比如查找某个数字,或者某个字符串,也可以查找从数值、字符到文件等各种类型的数据。

使用方法

  1. 首先要保证数组是有序的。
  2. 确定查找区间(一般是整个数组),并计算出区间中间位置 mid。
  3. 比较目标值与中间值的大小关系,如果目标值小于中间值,则在左半部分继续查找,否则在右半部分查找。
  4. 重复步骤 2 和 3,直到查找到目标值为止。

以下是一个 Python 代码示例:

def binary_search(array, target):
    low, high = 0, len(array) - 1
    while low <= high:
        mid = (low + high) // 2
        if array[mid] == target:
            return mid
        elif array[mid] < target:
            low = mid + 1
        else:
            high = mid - 1
    return -1

下面是一个简单的示例,演示如何用 Python 实现二分查找。

# 在有序数组中查找特定元素的位置

array = [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]

def binary_search(array, target):
    low, high = 0, len(array) - 1
    while low <= high:
        mid = (low + high) // 2
        if array[mid] == target:
            return mid
        elif array[mid] < target:
            low = mid + 1
        else:
            high = mid - 1
    return -1

# 查找数字 9 和 20

print(binary_search(array, 9))  # 4
print(binary_search(array, 20)) # -1

这个例子中,我们定义一个有序数组,然后使用二分查找算法查找数字 9 和 20 的位置。由于数组中包含数字 9,因此它的位置是 4,而数字 20 不在数组中,因此返回 -1。

另一个示例展示了如何找到一个字符串在一个已排序的字符串列表中的索引。

# 在有序字符串列表中查找目标字符串的位置

words = ["apple", "cabbage", "mango", "orange", "pear", "peach", "pineapple"]

def binary_search(words, target):
    low, high = 0, len(words) - 1
    while low <= high:
        mid = (low + high) // 2
        if words[mid] == target:
            return mid
        elif words[mid] < target:
            low = mid + 1
        else:
            high = mid - 1
    return -1

# 查找单词 "mango" 和 "banana"

print(binary_search(words, "mango"))    # 2
print(binary_search(words, "banana"))   # -1

在这个例子中,我们定义了一个字符串列表,并使用二分查找算法查找字符串 "mango" 和 "banana" 的位置。由于列表中包含字符串 "mango",因此它的索引为 2,而字符串 "banana" 不在列表中,因此返回 -1。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解二分查找算法原理与使用方法 - Python技术站

(0)
上一篇 2023年3月27日
下一篇 2023年3月27日

相关文章

  • Python实现简单遗传算法(SGA)

    下面是详细讲解“Python实现简单遗传算法(SGA)”的完整攻略,包括算法原理、Python实现和两个示例说明。 算法原理 简单遗传算法(SGA)是一种基于自然选择和遗传进化的优化算法,其基本思想是通过模拟生物进化过程,不断优化的。SGA的步骤如下: 初始化种群,随机生成一组初始解。 评估种群中每个个体的度,根据适应度选择优的个体。 通过交叉和变异操作,产…

    python 2023年5月14日
    00
  • Python实现的基于优先等级分配糖果问题算法示例

    以下是关于“Python实现的基于优先等级分配糖果问题算法示例”的完整攻略: 简介 糖果分配问题是一个经典的问题,通常涉及到将一定数量的糖果分配给一组孩子。在这个问题中,每个孩子都有一个优先级,我们需要按照优先级分配糖果,同时确保每个孩子至少分配到一个糖果。本教程将介绍如何使用Python实现基于优先等级分配糖果问题的算法。 步骤 1. 定义函数 首先,我们…

    python 2023年5月14日
    00
  • Python中数字以及算数运算符的相关使用

    下面是详细讲解“Python中数字以及算数运算符的相关使用”的完整攻略。 1. 数字类型 在Python中,数字类型包括整数、浮点数和复数。其中,整数是没有小数部的数字浮点数是带有小数部分的数字,而复数是由实数和数部分组成的数字。 1.1 整数 在Python中,整数类型用int表示,可以进行加、减、乘、除、模、幂等运算。 a = 10 b = 3 prin…

    python 2023年5月14日
    00
  • Python基本运算几何运算处理数字图像示例

    Python基本运算、几何运算、处理数字图像示例 Python是一种高级编程语言,它具有简单易学、功能强大、可扩展性强等特点。本文将介绍Python中的基本运算、几何运算和数字图像处理,并提供两个示例说明。 1. 基本运算 Python中的基本运算包括加、减、乘、除、取模、幂等运算。这些运算符可以用于数字、字符串、列表、元组等数据类型。 1.1 数字运算 a…

    python 2023年5月14日
    00
  • 详解Python查找算法的实现(线性,二分,分块,插值)

    下面是关于“详解Python查找算法的实现(线性,二分,分块,插值)”的完整攻略。 1. 查找算法概述 查找算法是一种用在数据集合中查找特定元素的算法。常见的查找算法包括线性查找、二分查找、分块查找和插值查找。在Python中,我们可以使用各种数据结构和算法实现这些查找算法。 2. 查找算法实现 2.1 线性查找 线性查找是一种简单的查找算法,它的基本思想是…

    python 2023年5月13日
    00
  • Python实现的knn算法示例

    Python实现的knn算法示例 K最近邻(KNN)是一种基于实例的学习方法,它将新数据点分配给与其最相似的K个训练数据点之一。在本攻略中,我们将介绍如何使用Python实现KNN算法,并提供两个示例来说明如何使用KNN算法进行分类和回归。 步骤1:了解KNN算法 在KNN算法中,我们需要考虑以下因素: K值:K值是指用于分类或回归的最近邻居的数量。通常,我…

    python 2023年5月14日
    00
  • 使用Python进行数独求解详解(二)

    使用Python进行数独求解详解(二) 本文将继续介绍如何使用Python进行数独求解。我们将介绍如何使用回溯算法和剪枝技巧来提高求解效率。同时,我们提供两个示例,分别演如何使用Python求解简单和困难的数独谜题。 回溯算法和剪枝技巧 回溯算法是一种通过尝试所有可能的解来求解问题的算法。在数独求解中,回溯算法可以通过递归地尝试每个空格的可能来求解数独谜题。…

    python 2023年5月14日
    00
  • Python双版本计算器详解

    以下是关于“Python双版本计算器详解”的完整攻略: 简介 Python是一种流行的编程语言,它可以用于开发各种应用程序,包括计算器。本教程将介绍如何使用Python开发一个双版本计算器,支持Python 2和Python 3。 Python 2和Python 3的差异 Python 2和Python 3有一些差异,这些差异可能会影响计算器的开发。以下是一…

    python 2023年5月14日
    00
合作推广
合作推广
分享本页
返回顶部