0

0

c++中如何实现数组的归并排序递归版_c++分治算法代码实现【详解】

尼克

尼克

发布时间:2026-01-22 11:50:03

|

993人浏览过

|

来源于php中文网

原创

c++kquote>归并排序递归版的核心逻辑是分治:先二分至子数组长度≤1,再合并已排序子数组;关键在merge过程,需用临时数组避免覆盖,三指针合并后拷回原数组。

c++中如何实现数组的归并排序递归版_c++分治算法代码实现【详解】

归并排序递归版的核心逻辑是什么

归并排序递归版本质是「分治」:把数组不断二分直到子数组长度 ≤ 1(自然有序),再逐层合并两个已排序的子数组。关键不在“递归调用”,而在 merge 过程——它必须用额外空间暂存结果,否则原地合并会覆盖未读取的数据。

如何正确写 merge 函数避免越界和覆盖

常见错误是直接往原数组 arr 写入,却没备份左/右半段;或下标计算错导致访问 arr[mid+1] 越界。必须用临时数组保存合并结果,再整体拷回。

  • left 子数组范围是 [l, m](闭区间),right[m+1, r]
  • 三指针:i 指向左段起始,j 指向右段起始,k 指向临时数组起始
  • 合并完后,用 std::copy 或循环把 temp[0, r-l+1) 段拷回 arr[l] 开始的位置

c++ 递归归并排序完整可运行代码

以下代码通过 vector 实现,避免手动管理内存,同时标注了易错点:

#include 
#include 

void merge(std::vector& arr, int l, int m, int r) { std::vector temp(r - l + 1); // 临时空间,大小必须是子数组总长 int i = l, j = m + 1, k = 0;

while (i zuojiankuohaophpcn= m && j zuojiankuohaophpcn= r) {
    if (arr[i] zuojiankuohaophpcn= arr[j]) {
        temp[k++] = arr[i++];
    } else {
        temp[k++] = arr[j++];
    }
}

while (i zuojiankuohaophpcn= m) temp[k++] = arr[i++];
while (j zuojiankuohaophpcn= r) temp[k++] = arr[j++];

// 必须拷回原位置:从 arr[l] 开始,共 temp.size() 个元素
std::copy(temp.begin(), temp.end(), arr.begin() + l);

}

MCP Market
MCP Market

MCP Servers集合平台,帮你找到最好的MCP服务器

下载

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

void mergeSort(std::vector& arr, int l, int r) { if (l

// 使用示例: // std::vector v = {38, 27, 43, 3, 9, 82, 10}; // mergeSort(v, 0, v.size() - 1);

为什么不能用 int arr[] 直接传参

函数参数写 void mergeSort(int arr[], int l, int r) 看似简洁,但实际是 int*,无法获取数组长度,r 完全依赖调用方传入——一旦错传(比如把 sizeof(arr)/sizeof(*arr) 写在函数内),就会越界。用 std::vector 或传入迭代器范围(如 begin, end)更安全、更现代。

另外,递归深度是 O(log n),但每层 merge 都要分配临时空间,总空间复杂度是 O(n),这点常被忽略——如果内存受限,得考虑迭代版或原地归并(后者实现复杂且不稳定)。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

757

2023.08.22

string转int
string转int

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

338

2023.08.02

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

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

542

2024.08.29

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

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

53

2025.08.29

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

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

197

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.11.23

java中void的含义
java中void的含义

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

97

2025.11.27

页面置换算法
页面置换算法

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

404

2023.08.14

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

5

2026.01.22

热门下载

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

精品课程

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

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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