二分查找搜索算法

二分查找

高效的搜索算法,它适用于已排序的数组。其基本原理是通过反复将查找区间缩小一半来定位目标元素的位置。以下是它的优缺点:

优点:

效率高:对于大型数据集,二分查找的时间复杂度是O(log n),比线性查找(O(n))更快。

空间效率:由于不需要额外存储除目标数组之外的数据,空间开销较小。

稳定性:对于有序数组,二分查找不会改变原有顺序。

缺点:

前提条件:数据必须是有序的,如果数组无序,则无法使用二分查找。

不适合动态插入或删除:因为每次查找都需要更新分割点,插入和删除操作会变得复杂。

实现原理:

初始化两个指针,指向数组首尾。

计算中间索引,比较中间值与目标值。

如果目标值等于中间值,返回中间索引;若小于中间值,继续在左半部分查找;若大于,继续在右半部分查找。

递归地重复步骤2和3,直到找到目标值或者区间为空。

实际应用:

二分查找广泛应用于搜索引擎、数据库查询、路径查找等需要快速定位特定元素的场景。

c 复制代码
Python实现示例:

Python
def binary_search(arr, target):
    low = 0
    high = len(arr) - 1

    while low <= high:
        mid = (low + high) // 2
        if arr[mid] == target:
            return mid
        elif arr[mid] < target:
            low = mid + 1
        else:
            high = mid - 1
            
    return -1  # 如果找不到,返回-1表示未在数组中

# 示例
arr = [1, 3, 5, 7, 9]
target = 5
result = binary_search(arr, target)
if result != -1:
    print(f"元素 {target} 的位置是:{result}")
else:
    print(f"{target} 不在数组中")
相关推荐
276695829217 分钟前
东方航空 m端 wasm req res分析
java·python·node·wasm·东方航空·东航·东方航空m端
星月昭铭1 小时前
Spring AI调用Embedding模型返回HTTP 400:Invalid HTTP request received分析处理
人工智能·spring boot·python·spring·ai·embedding
Dreamsi_zh1 小时前
Python爬虫02_Requests实战网页采集器
开发语言·爬虫·python
weixin_448617053 小时前
疏老师-python训练营-Day30模块和库的导入
开发语言·python
程序员三藏3 小时前
Web UI自动化测试之PO篇
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
旧时光巷4 小时前
【Flask 基础 ①】 | 路由、参数与模板渲染
后端·python·零基础·flask·web·模板渲染·路由系统
java1234_小锋4 小时前
【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 微博评论IP地图可视化分析实现
python·自然语言处理·flask
golitter.4 小时前
python的异步、并发开发
开发语言·python
陈敬雷-充电了么-CEO兼CTO5 小时前
强化学习三巨头PK:PPO、GRPO、DPO谁是大模型训练的「王炸」?
人工智能·python·机器学习·chatgpt·aigc·ppo·grpo
SiYuanFeng6 小时前
【问题未解决-寻求帮助】VS Code 中使用 Conda 环境,运行 Python 后 PowerShell 终端输出内容立即消失
开发语言·python·conda