0

0

C++怎么实现快速排序 C++ quick_sort算法递归与非递归写法【考研】

冰火之心

冰火之心

发布时间:2026-02-02 18:20:01

|

912人浏览过

|

来源于php中文网

原创

递归版 quick_sort 需确保分区后左右子区间不越界:若 partition 返回 pivot_idx,则左递归为 quick_sort(arr, left, pivot_idx-1),右递归为 quick_sort(arr, pivot_idx+1, right),并以 left >= right 为终止条件。

c++怎么实现快速排序 c++ quick_sort算法递归与非递归写法【考研】

递归版 quick_sort 怎么写才不越界

递归实现的核心是分区(partition)+ 递归调用左右子区间,但考研代码题常因边界处理出错导致段错误或死循环。关键在于 partition 返回的基准索引是否能安全划分区间。

常见错误:把 leftright 当成闭区间却用开区间逻辑递归,比如写成 quick_sort(arr, i+1, right) 却没保证 i+1 ;或者 partition 返回值未严格落在 [left, right] 内。

  • 统一用闭区间 [left, right],递归前必须判断 if (left >= right) return;
  • partition 推荐使用「挖坑法」或「双指针法」,避免交换后漏判;返回值应为基准最终位置 pivot_idx,且满足 left
  • 递归调用写成 quick_sort(arr, left, pivot_idx - 1)quick_sort(arr, pivot_idx + 1, right),确保子区间不重叠、不越界
int partition(vector& a, int left, int right) {
    int pivot = a[left];
    while (left < right) {
        while (left < right && a[right] >= pivot) right--;
        a[left] = a[right];
        while (left < right && a[left] <= pivot) left++;
        a[right] = a[left];
    }
    a[left] = pivot;
    return left;
}

void quick_sort(vector& a, int left, int right) { if (left >= right) return; int p = partition(a, left, right); quick_sort(a, left, p - 1); quick_sort(a, p + 1, right); }

非递归版用 stack 模拟时栈里存什么

非递归本质是手动管理递归调用栈,但考研现场手写容易堆栈元素类型混乱——存数组指针?存下标对?存结构体?最稳妥的是只存两个 int:左边界和右边界。

错误做法:压入单个索引、压入指针(C++ 中易悬空)、或每次压入四个数(如左右+pivot),增加调试难度且不符合考题简洁要求。

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

萝卜简历
萝卜简历

免费在线AI简历制作工具,帮助求职者轻松完成简历制作。

下载
  • stack> 或两个 stack,推荐前者,语义清晰
  • 初始压入 {0, n-1},每次弹出一对 (l, r),做完 partition 后,仅当子区间合法才压入——即 if (l ,if (p+1
  • 注意:非递归版的 partition 必须与递归版完全一致,否则行为不等价
void quick_sort_iterative(vector& a) {
    int n = a.size();
    if (n <= 1) return;
    stack> stk;
    stk.push({0, n - 1});
    while (!stk.empty()) {
        auto [l, r] = stk.top(); stk.pop();
        if (l >= r) continue;
        int p = partition(a, l, r);
        if (l < p - 1) stk.push({l, p - 1});
        if (p + 1 < r) stk.push({p + 1, r});
    }
}

考研笔试里要不要写随机化 pivot

标准快排最坏时间复杂度 O(n²),出现在已排序或逆序输入时。但考研算法题几乎从不考察性能优化,而是考逻辑正确性与边界控制能力。随机化 pivot 虽能规避最坏情况,反而会引入额外考点(如 rand() 初始化、取模边界),增加出错概率。

  • 除非题目明确要求「期望时间复杂度 O(n log n)」,否则默认用首元素或中点作 pivot 即可
  • 若真要加随机化,务必写 srand(time(0))(虽然笔试不运行,但写全更稳妥),且 swap(a[left], a[left + rand() % (right - left + 1)]) 避免 % 为 0 的崩溃
  • 更现实的做法:在 partition 前加一句 swap(a[left], a[(left + right) / 2]);,简单破序又不引入新依赖

vector 传参用引用还是指针

考研 C++ 代码题中,函数参数必须高效且无歧义。传 vector 值会触发深拷贝,O(n) 开销且可能超时;传指针需额外判空,还易写成 vector* a 导致解引用错误。

  • 一律用 vector& 引用,既避免拷贝,又保持语法简洁
  • 不要写 const vector&——因为要原地排序,必须可修改
  • 如果题目给的是普通数组(如 int a[]),则用 int* + len 参数,此时 partition 中所有下标运算都基于指针偏移,别混用 vector 语法

真正容易丢分的地方不在算法本身,而在:分区后忘了把 pivot 放回、递归调用写反了左右顺序、非递归压栈漏判区间长度、或者笔试时用 std::sort 直接交卷——那不算实现 quick_sort。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

422

2023.08.14

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

59

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

18

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

9

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

3

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

4

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

62

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

55

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

27

2026.01.31

热门下载

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

精品课程

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

共94课时 | 8.3万人学习

C 教程
C 教程

共75课时 | 4.4万人学习

C++教程
C++教程

共115课时 | 15.4万人学习

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

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