news 2026/5/16 3:45:32

C语言归并排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言归并排序

归并排序

  1. 归并排序——最常见的分治排序算法;
  2. 把两个已经有序的数组合并成一个有序数组

一、归并排序思路

  1. 分:递归地把当前区间 [left, right] 一分为二,直到区间长度 ≤1。
  2. 治:把两个已经有序的子区间合并成一个有序区间。
  3. 合并时需要额外 O(n) 的辅助空间;时间复杂度稳定 O(n log n),是稳定排序。

二、核心过程:

功能:把两个有序子数组 a[low…mid] 和 a[mid+1…high] 原地归并到临时数组 tmp,最后再拷回去。

关键点

  • 用双指针 i、j 分别扫描左右两段;
  • 每次把较小的元素放到 tmp[k],指针后移;
  • 某一段耗尽后,把另一段剩余元素全部追加;
  • 最后把 tmp[low…high] 复制回原数组对应位置。

三、完整代码

#include<stdio.h>#include<stdlib.h>#include<string.h>/* 合并两个有序区间 a[low..mid] 与 a[mid+1..high] */staticvoidmerge(int*a,intlow,intmid,inthigh){inti=low,j=mid+1,k=0;int*tmp=malloc((high-low+1)*sizeof(int));if(!tmp){perror("malloc");exit(EXIT_FAILURE);}/* 二路归并 */while(i<=mid&&j<=high)tmp[k++]=(a[i]<=a[j])?a[i++]:a[j++];while(i<=mid)tmp[k++]=a[i++];while(j<=high)tmp[k++]=a[j++];/* 拷回原数组 */memcpy(a+low,tmp,(high-low+1)*sizeof(int));free(tmp);}/* 归并排序递归主体 */staticvoidmerge_sort(int*a,intlow,inthigh){if(low<high){intmid=low+(high-low)/2;/* 防溢出 */merge_sort(a,low,mid);merge_sort(a,mid+1,high);merge(a,low,mid,high);}}/* 对外接口:排序长度为 n 的整型数组 */voidmerge_sort_int(int*a,size_tn){if(n>1)merge_sort(a,0,(int)n-1);}/* ---- 测试 ---- */intmain(void){intarr[]={8,3,6,7,1,5,2,4};size_tn=sizeof(arr)/sizeof(arr[0]);merge_sort_int(arr,n);for(size_ti=0;i<n;++i)printf("%d%c",arr[i],i+1==n?'\n':' ');return0;}

四、常见变形与考点

  1. 链表归并排序
    链表无法随机拆分,用快慢指针找中点,然后递归归并,空间可做到 O(log n)(递归栈)。

  2. 外排序
    文件太大内存放不下,先分段生成有序临时文件,再做多路归并。

  3. 逆序对
    在 merge 过程中,若左边元素 > 右边元素,则左边剩余元素都与该右边元素构成逆序对,可顺手统计。

  4. 原地归并
    经典算法有 “旋转法” 或 “缓冲法”,但实现复杂且常数大,实际工程里仍用辅助数组。

五、复杂度小结

  • 时间:每次合并 O(n),共 log₂n 层 ⇒ O(n log n)
  • 空间:辅助数组 O(n) + 递归栈 O(log n)
  • 稳定性:稳定(相等元素相对顺序不变)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/16 3:44:03

java计算机毕业设计社区疫情防控管理系统 街区居民防疫信息综合平台 基层社区疫情联防联控小程序

计算机毕业设计社区疫情防控管理系统orcuw9&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。疫情反复期间&#xff0c;社区卡口纸质登记、微信群接龙、人工电话追核酸造成数据碎片…

作者头像 李华
网站建设 2026/5/16 3:44:17

vue基于Spring Boot框架的 蛋糕购物商城的设计_k495g9n8

目录具体实现截图项目介绍论文大纲核心代码部分展示项目运行指导结论源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作具体实现截图 本系统&#xff08;程序源码数据库调试部署讲解&#xff09;同时还支持java、ThinkPHP、Node.js、Spring B…

作者头像 李华
网站建设 2026/5/14 6:25:15

《深入理解 NumPy 广播机制:从原理到实战的全景解析》

《深入理解 NumPy 广播机制&#xff1a;从原理到实战的全景解析》 在 Python 的科学计算世界中&#xff0c;NumPy 是一座绕不开的高峰。它以高效的数组操作、丰富的数学函数和底层 C 实现的性能优势&#xff0c;成为数据分析、机器学习、图像处理等领域的基础工具。而在 NumPy …

作者头像 李华
网站建设 2026/5/7 18:08:23

低代码 | 低代码库研究 + 拖拽

问题&#xff1a;有哪些低代码库&#xff0c;他们的区别是&#xff1f;并整理相关技术差异。一、低代码的总体定位对比&#xff08;平台层面&#xff09;对比维度ADOxxGoViewtmagic-editorAJ-Report研究属性学术 工业平台工程实践为主大厂工程级方案工业报表系统核心定位建模工…

作者头像 李华
网站建设 2026/5/9 19:25:12

基于Python与Django的白泽自动化运维系统设计与实现

基于Python与Django的白泽自动化运维系统设计与实现 白泽自动化运维系统&#xff1a;基于Python与Django的毕业设计完整解决方案 引言&#xff1a;为什么选择自动化运维系统作为毕业设计&#xff1f; 在当今数字化时代&#xff0c;企业IT基础设施日益复杂&#xff0c;传统的…

作者头像 李华