返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言简明讲解归并排序的应用
  • 235
分享到

C语言简明讲解归并排序的应用

2024-04-02 19:04:59 235人浏览 薄情痞子
摘要

目录一.归并排序1.1归并排序引入1.2归并排序的概念1.3归并排序的原理1.4实例说明1.5具体步骤说明1.6代码实现1.7性能分析一.归并排序 1.1归并排序引入 对于堆排序来说

一.归并排序

1.1归并排序引入

对于堆排序来说,因为用到了完全二叉树的深度是(log2n+1)的特性,所以效率就比较高,但是堆结构的设计比较复杂,现在我们想要可以直接利用完全二叉树来排序的方法,这个方法就是归并排序。

1.2归并排序的概念

归并排序是建立在归并操作上的一种有效的排序算法,归并排序对序列的元素进行逐层折半分组,然后从最小分组开始比较排序,合并成一个大的分组,逐层进行,最终所有的元素都是有序的。

1.3归并排序的原理

原理:假设初始序列含有n个记录,则可以看成是n个有序的子序列,每个子序列的长度为1,然后两两归并,得到n/2个长度为2或1的有序子数列,再两两归并,如此重复直到得到一个长度为n的有序序列为止。

1.4实例说明

(1).以4,5,8,1,7,2,6,3为例,排序过程:

(2).以84,9,18,19,48,12,90,84,8,12为例,排序过程:

这里的两两合并指的是两个组合并;

每组的数据单独看是有序的。

1.5具体步骤说明

以实例中的第一个为例:

序列逐层拆分如下:

然后从下往上逐层合并,首先对第一层序列1(只包含元素4)和序列2(只包含元素5)进行合并

创建一个大序列,序列长度为两个小序列长度之和,A、B指针分别指向两个小序列的第一个元素,C指向大序列的第一个元素

比较A、B指向的元素,4小于5,将4填入C指向的元素,C、A往右移一位

此时,序列1已经没有元素,将序列2的元素依次填入大序列中

序列8和1,序列7和2,序列6和3,用同样的方式填入新的序列

接着,以4、5为序列1,1、8为序列2,继续进行合并

创建一个序列长度为4的大序列,A指向序列1的第一个元素4,B指向序列2的第一个元素1,C指向大序列的第一个元素

4和1比较,4大于1,1填入C指向的元素,C、B往右移一位

4和8比较,4小于8,4填入C指向的元素,C、A往右移一位

5和8比较,5小于8,5填入C指向的元素,C、A往右移一位

自此,序列1已经没有元素,将序列2的元素依次填入大序列中

序列2、7和序列3、6以同样的方式合并成新的序列

最后,将序列1、4、5、8和序列2、3、6、7以同样的方式继续合并成新的序列

所有元素均已排好。

1.6代码实现

void MergeSort(int *arr, int len)
{
	for(int i=1; i<len; i*=2)// O(logn)
	{
		Merge(arr, len, i);
	}
}
//一次划分函数  核心函数  //返回基准值最终所在下标
int Partition(int *arr, int left, int right)
{
	//先讲arr数组里的[left, right]的第一个值 作为基准值
	int tmp = arr[left];
	while(left < right)
	{
		while(left<right && arr[right] > tmp)//左右边界没有相遇且当前右边的值大于基准值tmp
		right--;
		if(left < right)//如果此时,左右边界没有相遇,那就只能证明右边right找到了一个小于等于基准值tmp的值
		{
			arr[left] = arr[right];
		}
		else
		{
			break;
		}
		while(left<right && arr[left] <= tmp)//左右边界没有相遇且当前左边的值小于等于基准值tmp
		left++;
		if(left < right)//如果此时,左右边界没有相遇,那就只能证明左边left找到了一个大于基准值tmp的值
		{
			arr[right] = arr[left];
		}
		else
		{
			break;
		}
	}
	arr[left] = tmp;//此时 因为 left == right
	return left;//return right ok
}

1.7性能分析

  • 时间复杂度:最好,最坏,平均的时间复杂度均为O(nlogn)。
  • 空间复杂度:空间复杂度O(n)。
  • 稳定性:稳定。

到此这篇关于C语言简明讲解归并排序的应用的文章就介绍到这了,更多相关C语言归并排序内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C语言简明讲解归并排序的应用

本文链接: https://lsjlt.com/news/149392.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言简明讲解归并排序的应用
    目录一.归并排序1.1归并排序引入1.2归并排序的概念1.3归并排序的原理1.4实例说明1.5具体步骤说明1.6代码实现1.7性能分析一.归并排序 1.1归并排序引入 对于堆排序来说...
    99+
    2024-04-02
  • C语言简明讲解快速排序的应用
    目录快速排序1.1快速排序引入1.2快速排序的基本思想1.3快速排序的排序流程1.4实例说明1.5代码实现1.6性能分析快速排序 快速排序,说白了就是给基准数据找其正确索引位置的过程...
    99+
    2024-04-02
  • C语言归并排序如何应用
    这篇文章主要介绍“C语言归并排序如何应用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C语言归并排序如何应用”文章能帮助大家解决问题。一.归并排序1.1归并排序引入对于堆排序来说,因为用到了完全二叉...
    99+
    2023-06-30
  • C语言递归实现归并排序详解
    归并排序递归实现还是比较难理解的,感觉涉及递归一般理解起来都会比较有难度吧,但是看了b站视频,然后照着打下来,然后自己写了点注释,就发现不知不觉都大概懂了。 这里的归并讲的是升序排序...
    99+
    2024-04-02
  • c语言排序之归并排序(递归和非递归)
    目录递归代码流程非递归代码流程两者比较时间复杂度代码(递归)代码(非递归)递归代码流程 归并就是把两个或多个序列合并,这里只介绍二路归并,就是不断的把序列分为2组,直到每个组有一个元...
    99+
    2024-04-02
  • C语言常见排序算法归并排序
    目录前言 一、归并排序1.1 基本思想1.2 算法思想1.3 程序设计思想1.4 程序实现1.5 归并排序的特性总结前言 本期为大家带来的是常见排序算法中的归并排序,博主在...
    99+
    2024-04-02
  • C语言简明讲解预编译的使用
    目录小复习1、内置符号2、自定义符号3、自定义宏4、条件编译小复习 预处理,预编译是编译的第一步。 会有三件基本的事情发生: 引入#include去除注释修改#define 1、内置...
    99+
    2024-04-02
  • C语言简明讲解变量的属性
    目录一、C语言中的变量属性二、auto 关键字三、register 关键字四、static 关键字五、extern 关键字六、小结一、C语言中的变量属性 C语言中的变量可以有自己的属...
    99+
    2024-04-02
  • C语言简明清晰讲解枚举
    目录概述简单使用入门判断自定义数值一种不严格的写法概述 一个类型,值只能是一堆值中的一个。 比如星期几,只会是星期一到星期天。 用数值表示的话就是0到6,但是0到6不太好理解。 而枚...
    99+
    2024-04-02
  • C语言非递归算法解决快速排序与归并排序产生的栈溢出
    目录1、栈溢出原因和递归的基本认识2、快速排序(非递归实现)3、归并排序(非递归实现)建议还不理解快速排序和归并排序的小伙伴们可以先去看我上一篇博客​​​​​​哦!C语言超详细讲解排...
    99+
    2024-04-02
  • C语言简明清晰讲解结构体
    目录本质简单使用一些写法我套我自己内存对齐举例-int char char举例-char int char举例-char char int由结构体指针访问成员本质 一些值的集合。 简...
    99+
    2024-04-02
  • C语言简明讲解队列的实现方法
    目录前言队列的表示和实现队列的概念及结构代码实现束语前言 大家好啊,我又双叒叕来水博客了,道路是曲折的,前途是光明的,事物是呈螺旋式上升的,事物最终的发展结果还是我们多多少少能够决定...
    99+
    2024-04-02
  • c++深入理解归并排序的用法
    目录分治算法归并排序怎么分递归的出口“并”的实现加到“分”函数里完整代码hello 昨天发了个堆排序,竟然上了热榜 所以,今天来发一下归并排序 上次的堆排序似乎好多人没看懂,其实这些...
    99+
    2024-04-02
  • C语言简明讲解操作符++和--的使用方法
    目录一、++与--操作符的本质二、++与-- 操作符使用分析三、小结一、++与--操作符的本质 ++ 和 -- 操作符对应两条汇编指令 前置 变量自增(减)1取变量值 后置 取变量值...
    99+
    2024-04-02
  • C语言简明讲解类型转换的使用与作用
    目录一、类型之间的转换二、强制类型转换三、隐式类型转换四、表达式中的隐式类型转换五、小结一、类型之间的转换 C语言中的数据类型可以进行转换 强制类型转换隐式类型转换 二、强制类型转...
    99+
    2024-04-02
  • C语言简明讲解单引号与双引号的使用
    目录一、单引号和双引号二、小贴士三、程序实例分析1四、程序实例分析2五、容易混淆的代码六、小结一、单引号和双引号 C语言中的单引号用来表示字符字面量C语言中的双引号用来表示字符串字面...
    99+
    2024-04-02
  • C语言排序方法(冒泡,选择,插入,归并,快速)
    目录1.冒泡排序2.选择排序3.插入排序4.归并排序5.快速排序总结1.冒泡排序 它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序错误就把他们交换过来。走访元素的工作是...
    99+
    2024-04-02
  • C语言超详细讲解排序算法上篇
    目录1、直接插入排序2、希尔排序(缩小增量排序)3、直接选择排序4、堆排序进入正式内容之前,我们先了解下初阶常见的排序分类 :我们今天讲前四个! 1、直接插入排序 基本思...
    99+
    2024-04-02
  • C语言超详细讲解排序算法下篇
    目录1、冒泡排序2、快速排序 ( 三种方法 )3、归并排序4、排序算法复杂度及稳定性分析 上期学习完了前四个排序,这期我们来学习剩下的三个排序 1、冒泡排序 &n...
    99+
    2024-04-02
  • 通俗易懂的C语言快速排序和归并排序的时间复杂度分析
    目录快速排序和归并排序的时间复杂度分析——通俗易懂归并排序的时间复杂度分析快速排序的时间复杂度快速排序的最坏情况O(n^2)总结快速排序和归并排序的时间复杂度...
    99+
    2023-01-28
    C语言排序时间复杂度 C语言快速排序归并排序
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作