0

0

C++怎么实现二分查找_C++有序数组搜索【高效】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-03 08:54:12

|

880人浏览过

|

来源于php中文网

原创

std::lower_bound比手写二分更可靠,因其采用经充分测试的左闭右开区间实现,天然规避越界、漏判、死循环等off-by-one错误,并提供安全的存在性判断方式。

c++怎么实现二分查找_c++有序数组搜索【高效】

std::lower_bound 为什么比手写二分更可靠

手写 binary_search 容易越界、漏判边界、死循环,而 std::lower_bound 是标准库经过充分测试的实现,底层用的是「左闭右开」区间,天然规避多数 off-by-one 错误。

它返回第一个 ≥ 目标值的迭代器,配合 != vec.end()*it == target 两步就能安全判断存在性。手写时若用「左闭右闭」,left 的循环条件和 <code>mid 更新方式稍有偏差就会卡住或越界。

  • 必须传入随机访问迭代器(vectorarray 可用,list 不行)
  • 容器必须严格升序(不能含重复且无序,也不能是降序)
  • 自定义类型需提供 运算符,或传入比较函数,如 <code>std::lower_bound(v.begin(), v.end(), x, [](int a, int b) { return a

手写二分时 mid 计算为什么不能写成 (left + right) / 2

leftright 都接近 INT_MAX 时,left + right 会整数溢出,结果为负数,后续计算彻底失控 —— 这不是理论风险,是真实踩过的坑,尤其在处理大数组索引或 long 类型下标时。

正确写法是 mid = left + (right - left) / 2,等价但不溢出。C++20 起也可用 std::midpoint(left, right),它对有符号/无符号、指针都安全。

Mokker AI
Mokker AI

AI产品图添加背景

下载

立即学习C++免费学习笔记(深入)”;

  • 如果用 size_t 做下标(常见于 vector.size()),right - left 永远非负,但 left + (right - left) / 2 仍是首选,避免混淆
  • 别依赖编译器优化:即使你确定数据小,也别省这个括号和减法,代码可移植性差一点,问题就出在生产环境的大内存机器上

查找失败时返回什么?不同函数行为差异很大

std::binary_search 只返回 bool,查不到就是 false,不告诉你位置;std::lower_boundstd::upper_bound 返回迭代器,失败时都等于 end() —— 但含义不同:lower_bound 指向第一个 ≥ 值的位置,upper_bound 指向第一个 > 值的位置。想查是否存在且取值,必须先判 != end(),再解引用比较。

  • 误把 std::binary_search 当作“返回下标”的函数,会导致编译错误(它没返回 int)
  • std::lower_bound 查找后直接 *it 而不检查是否 == end(),会触发未定义行为(解引用尾后迭代器)
  • 若要找最后一个等于目标的元素,得组合用 lower_boundupper_bound,而不是反复调用 binary_search

vector 数据量多大时 std::lower_bound 才比线性扫描快

理论分界点是 log₂(n) ≈ n/100 —— 算下来 n ≈ 1000 就开始体现优势。实测中,n 256 后 std::lower_bound 稳定胜出。

  • 如果数组是栈上小数组(如 int arr[16]),用 std::lower_bound(std::begin(arr), std::end(arr), x) 没问题,但别为了“看起来高级”强行套用
  • 编译器对小范围循环可能自动向量化,而二分的跳转反而打断流水线,所以性能不是单纯看 O(log n)
  • 真正影响性能的常是“是否已缓存”:若数组刚被遍历过,线性扫可能还在 L1 cache;若刚从磁盘读入且巨大,则二分的访存跳跃会放大 TLB miss

边界模糊的地方永远在“你实际的数据分布和访问模式”,不是教科书上的 n 值。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

597

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

43

2026.02.28

Golang 工程化架构设计:可维护与可演进系统构建
Golang 工程化架构设计:可维护与可演进系统构建

Go语言工程化架构设计专注于构建高可维护性、可演进的企业级系统。本专题深入探讨Go项目的目录结构设计、模块划分、依赖管理等核心架构原则,涵盖微服务架构、领域驱动设计(DDD)在Go中的实践应用。通过实战案例解析接口抽象、错误处理、配置管理、日志监控等关键工程化技术,帮助开发者掌握构建稳定、可扩展Go应用的最佳实践方法。

38

2026.02.28

Golang 性能分析与运行时机制:构建高性能程序
Golang 性能分析与运行时机制:构建高性能程序

Go语言以其高效的并发模型和优异的性能表现广泛应用于高并发、高性能场景。其运行时机制包括 Goroutine 调度、内存管理、垃圾回收等方面,深入理解这些机制有助于编写更高效稳定的程序。本专题将系统讲解 Golang 的性能分析工具使用、常见性能瓶颈定位及优化策略,并结合实际案例剖析 Go 程序的运行时行为,帮助开发者掌握构建高性能应用的关键技能。

35

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.5万人学习

C 教程
C 教程

共75课时 | 5.1万人学习

C++教程
C++教程

共115课时 | 20.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号