当前位置: 首页 > article >正文

归并排序(C语言)

归并排序的基本思想:归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。

一、步骤

1.首先,建立一个随机数组,如:以该数组为例

2.采用分治的思想对数组中的元素进行比较,将数组一份为二,midi = (left + right) / 2,分为[left,midi] [midi + 1,right]

3.重复第二步采用递归算法往深处递归,直到数组中只包含一个元素(不包含数组不存在的情况),故递归的结束条件是left == right

4.然后函数返回到上一层,对两个数进行比较,然后按照顺序插入临时数组tmp

5.当tmp数组有序时,拷贝到原数组中结束

归并排序的思想和二叉树的后序遍历类似

图片详述:

二、代码

void _MergeSort(int* a, int begin, int end, int* tmp)
{
	if (begin == end)
	{
		return;
	}

	int midi = (begin + end) / 2;
	//[begin,midi] [midi+1,end],一个数组一分为二

	_MergeSort(a, begin, midi, tmp);
	_MergeSort(a, midi + 1, end, tmp); //后序遍历递归

	int begin1 = begin, end1 = midi; //第一个数组
	int begin2 = midi + 1, end2 = end; //第二个数组
	int i = 0;

	while (begin1 <= end1 && begin2 <= end2) //只要有一个数组为空就结束
	{
		if (a[begin1] < a[begin2])
		{
			tmp[i++] = a[begin1++];
		}
		else
		{
			tmp[i++] = a[begin2++];
		}
	}

	while (begin1 <= end1) //第一个数组不为空,插入到第二个数组后面
	{
		tmp[i++] = a[begin1++];
	}
	while (begin2 <= end2) //第二个数组不为空,插入到第一个数组后面
	{
		tmp[i++] = a[begin2++];
	}

	memcpy(a + begin, tmp, sizeof(int) * (end - begin + 1));
}

void MergeSort(int* a, int n)
{
	int* tmp = (int*)malloc(sizeof(int) * n);
	_MergeSort(a, 0, n - 1, tmp); //由于tmp是malloc出来的,因此要建立一个子函数
                                    来递归,避免每一层都需要malloc
	free(tmp);
}

若看不懂,可以画图,一层一层的调试


http://www.kler.cn/a/397231.html

相关文章:

  • 类和对象——拷贝构造函数,赋值运算符重载(C++)
  • IQ Offset之工厂实例分析
  • Spring Boot 启动时自动配置 RabbitMQ 交换机、队列和绑定关系
  • 机器学习 决策树
  • 智能化护士排班系统的设计与实现(文末附源码)
  • 基于OpenCV的图片人脸检测研究
  • python基础知识(四)——发送请求、接口关联
  • 问:说说SpringDAO及ORM的用法?
  • MySQL技巧之跨服务器数据查询:基础篇-A数据库与B数据库查询合并--封装到存储过程中
  • Spring Boot基础教学:创建第一个Spring Boot项目
  • 背景替换大模型图像处理gradio部署服务
  • Vue 项目打包后环境变量丢失问题(清除缓存),区分.env和.env.*文件
  • 革新人脸图片智能修复
  • 【算法】【优选算法】前缀和(上)
  • ‌REST风格(Representational State Transfer)
  • 神经网络的正则化(一)
  • 设计模式:工厂方法模式和策略模式
  • “南海明珠”-黄岩岛(民主礁)领海基线WebGIS绘制实战
  • C# x Unity 从玩家控制类去分析命令模式该如何使用
  • 精通rust宏系列教程-调试过程宏
  • stm32 内部温度传感器使用
  • 封装一个省市区的筛选组件
  • 【提高篇】3.3 GPIO(三,工作模式详解 上)
  • MuMu模拟器安卓12安装Xposed 框架
  • python爬虫快速获取商品历史价格信息
  • Ubuntu 系统端口查询与管理详细分析