news 2026/2/15 1:54:32

排序算法-归并排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
排序算法-归并排序

在学习归并排序之前,个人认为需要掌握双指针的相关知识(快慢指针,左右指针之类的)。

归并排序是一种运用快慢指针与递归来实现的算法

思路

拆分过程-“归”的过程

对于数组:

5 4 3 2 1

我们先把其分为两部分:

5 4 和 3 2 1 //两个都可以,看你选择

5 4 3 和 2 1 //两个都可以,看你选择

然后再对于左右两部分再次拆分,直到分成一个元素

而这个过程,我们可以运用递归来进行数组的拆分

f(0 , 4)->f(0 , 2) + f(3 , 4)->f(0 , 1) + f(2 , 2) + f(3 , 3) + f(4, 4) //返回的是边界下标

而我们就可以利用这个过程将大数组转换成小数组,最终得到一个有序的数组

排序过程-“并”的过程

我们取递归返回的其中一个过程为例:

3 4 5 和 1 2

我们定义一个临时变量来存储部分排序好的元素,假设这个变量为temp

我们先比较 3 和 1,发现 1 比较小

于是我们把 1 放入temp

继续比较 3 和 2 , 发现 2 比较小

于是我们把 2 放入temp

这个时候右数组到头了,于是我们停止比较,并且把左数组剩下的元素全放到temp里面去

于是我们得到的temp就是

1 2 3 4 5

然后我们将temp赋值给原数组,把原数组覆盖掉

我们明显可以发现,和原来相比较,原数组更加有序了(已经有序了,我们取的是排序的最后一步)

代码实现

#include<iostream> using namespace std; const int N = 1e5; int arr[N]; int temp[N]; //辅助数组 void merge_sort(int l , int r){ //递归实现归并排序 if(l >= r) return; //只有一个元素或者没有,自然有序,不用管 int m = (l + r) / 2; //这里就是把数组拆开 merge_sort(l , m); //处理左边 merge_sort(m + 1 , r); //处理右边 int i = l , j = m + 1 , k = 0; //i和j分别代表左右数组的左边界起点 k是临时变量,作为temp数组的边界 while(i <= m && j <= r){ if(arr[i] > arr[j]){ temp[k] = arr[j]; //把小的数放进来 k++; j++; }else{ temp[k++] = arr[i++]; } } //接下来判断i和j哪个没走完,把剩下的元素放进去 while(i <= m) temp[k++] = arr[i++]; while(j <= r) temp[k++] = arr[j++]; //然后把temp覆盖arr,即把temp重新赋值给arr,arr的起始位置是l和r,temp的起始位置是0 for(i = l , k = 0 ; i <= r ; i++ , k++){ arr[i] = temp[k]; } } int main(){ int n; cin >> n; for(int i = 0 ; i < n ; i++){ cin >> arr[i]; } merge_sort(0 , n - 1); //将左边界和右边界传入 for(int i = 0 ; i < n ; i++){ cout << arr[i] << ' '; } cout << endl; return 0; }

总结

归并排序的整体难度起始不大,然后复杂度和稳定性这两个方面的话,我不清楚这个复杂度是怎么算出来的,但是我查出来是O()。归并排序不是一个稳定的算法,因为临时数组会反复地把原数组进行覆盖。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/7 9:45:29

PAT 1119 Pre- and Post-order Traversals

这一题的大意是说给出前序遍历和后序遍历&#xff0c;让我们找是否构造一个唯一的二叉树&#xff0c; 如果可以返回Yes&#xff0c;并输出中序遍历序列&#xff0c;如果不可以&#xff0c;那么就是输出No&#xff0c;并输出其中一种情况的中序遍历序列。 我们都知道通过前序和后…

作者头像 李华
网站建设 2026/2/8 0:11:09

Langchain-Chatchat问答系统灰度期间服务健康检查

Langchain-Chatchat问答系统灰度期间服务健康检查 在企业级AI应用逐步落地的今天&#xff0c;一个看似简单的“智能客服”背后&#xff0c;往往隐藏着复杂的系统架构与严苛的稳定性要求。尤其当这套系统承载的是金融、医疗或法律领域的私有知识时&#xff0c;任何一次服务中断、…

作者头像 李华
网站建设 2026/2/12 4:40:22

Langchain-Chatchat文档解析流程拆解:从PDF到语义检索的全过程

Langchain-Chatchat文档解析流程拆解&#xff1a;从PDF到语义检索的全过程 在企业知识管理日益复杂的今天&#xff0c;一个常见的挑战是&#xff1a;新员工反复询问“年假怎么算”&#xff0c;客服人员每天重复回答“退货流程是什么”。这些看似简单的问题背后&#xff0c;隐藏…

作者头像 李华
网站建设 2026/2/6 18:36:36

自动化测试ROI的核心价值与计算逻辑

在敏捷开发与DevOps普及的背景下&#xff0c;自动化测试已成为提升软件质量与交付效率的关键手段。然而&#xff0c;许多团队在推行自动化时面临一个核心问题&#xff1a;如何准确衡量其经济价值&#xff1f;ROI&#xff08;投资回报率&#xff09;正是连接技术投入与商业价值的…

作者头像 李华
网站建设 2026/2/12 5:52:44

高速采集在半导体测试的应用

在半导体检测领域&#xff0c;数据采集卡发挥着至关重要的作用。半导体检测涉及对芯片、晶圆等的电学参数、物理特性及可靠性指标等多方面的精准测量与分析&#xff0c;数据采集卡作为连接测试设备与被测对象的关键桥梁&#xff0c;能够高效地采集、转换并传输各种信号&#xf…

作者头像 李华
网站建设 2026/2/12 14:32:39

SegGISv3 添加后处理功能,视屏教程

GIS数据栈编辑&#xff1a;GIS数据栈【导读】SegGIS无人机遥感影像识别系统是一款专业级遥感影像AI识别与分析工具&#xff0c;集成了最先进的深度学习技术、多源地图服务和地理大模型智能分析功能&#xff0c;为测绘、规划、环保、农业等各行业提供一站式遥感影像解决方案。所…

作者头像 李华