二分查找法(Python)

作者: import_hello | 来源:发表于2018-04-10 00:12 被阅读0次

在 Python 中分别用循环和递归两种方式来实现二分查找法

本文的最新版本位于:https://github.com/iwhales/algorithms_notes
转载请注明出处:https://www.jianshu.com/u/5e6f798c903a

# -*- coding: utf-8 -*-
# 二分查找的时间复杂度是math.log(n,2)


def binary_search_loop(a_list: list, item: int):
    """
    循环方式
    :param a_list: 有序列表
    :param item: 被查找的目标项
    :return: 如果a_list中包含item,返回item的索引值,否则返回None
    """
    low = 0
    high = len(a_list) - 1
    while low <= high:
        mid = (low + high) // 2
        guess = a_list[mid]
        if guess == item:
            return mid
        elif guess > item:
            high = mid - 1
        else:
            low = mid + 1
    return None


def binary_search_recursive(a_list: list, item: int):
    """
    递归方式
    :param a_list: 有序列表
    :param item: 被查找的目标项
    :return: 如果a_list中包含item,返回item的索引值,否则返回None
    """
    mid = (len(a_list) - 1) // 2
    if len(a_list) == 1:
        if item == a_list[0]:
            return 0
        else:
            return None
    if item == a_list[mid]:
        return mid
    elif item > a_list[mid]:
        index = binary_search_recursive(a_list[mid + 1:], item)
        if index is None:
            return None
        return mid + 1 + index
    else:
        index = binary_search_recursive(a_list[:mid], item)
        return index


if __name__ == '__main__':
    my_list = [1, 2, 3, 4]
    assert binary_search_loop(my_list, 1) == 0
    assert binary_search_loop(my_list, 2) == 1
    assert binary_search_loop(my_list, 3) == 2
    assert binary_search_loop(my_list, 4) == 3
    assert binary_search_loop(my_list, 10) is None

    assert binary_search_recursive(my_list, 1) == 0
    assert binary_search_recursive(my_list, 2) == 1
    assert binary_search_recursive(my_list, 3) == 2
    assert binary_search_recursive(my_list, 4) == 3
    assert binary_search_recursive(my_list, 10) is None

相关文章

  • 二分查找法

    二分查找法 二分查找法(递归)

  • [老实李] 算法初探:二分查找法 Binary Search

    二分查找法主要用来解决查找的问题 1、二分查找法Binary Search (注)对于有序数列才能使用二分查找法。...

  • 二分法查找

    二分法基本查找 二分法遍历查找

  • 排序算法

    算法与数据结构基础 查找算法: 二分查找法: 简介:二分查找法又被称为折半查找法,用于预排序的查找问题 过程: 如...

  • 二分法查找

    二分法查找的前提是数组必须排序!!!二分法查找的前提是数组必须排序!!!二分法查找的前提是数组必须排序!!!二分法...

  • 二分排序法

    二分排序法,实际上是二分查找法+直接插入排序法的灵活组合。 先来看看二分查找法,二分查找法的前提是给出的队列是有序...

  • python二分查找算法

    文章概述 二分查找法介绍 简单查找与二分查找对比 二分查找  二分查找算法主要思想:在有序列表中查找指定元素,先从...

  • LeetCode 数组专题 1:二分查找

    二分查找法 说明:二分查找法在代码实现上有模板方法,一定要掌握。 1、二分查找法的使用前提:数组一定要是排好序的,...

  • 二分查找

    以二分法来提升查找效率 二分法查找到key的合适位置 put get delete 二分查找的查找操作为O(log...

  • 二分查找法

    在有序数组中,查找特定元素的方法有许多种,今天和大家分享的是二分查找法,二分查找法,也可以称为对半查找,折半查找,...

网友评论

    本文标题:二分查找法(Python)

    本文链接:https://www.haomeiwen.com/subject/xxowhftx.html