【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】

这篇具有很好参考价值的文章主要介绍了【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

目录

前言

1.冒泡排序

1.1冒泡排序动图

1.2冒泡排序源代码

1.3冒泡排序的特性总结

2.快速排序👑

2.1hoare版本实现思想

排序前

排序中

排序后

2.2hoare版本快排源代码

2.3分析先走

情况1🥇

情况2🥈


前言

交换类排序两个常见的排序算法【冒泡排序】、【快速排序】


交换排序基本思想:所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置。


交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言


1.冒泡排序

1.1冒泡排序动图

冒泡排序动图

1.2冒泡排序源代码

void BubbleSort(int* a, int n)
{
	assert(a);

	for (int j = 0; j < n - 1; ++j)
	{
		int exchange = 0;//这里的exchange的值作为是否交换的标志
		for (int i = 1; i < n - j; ++i)
		{
			if (a[i - 1] > a[i])
			{
				Swap(&a[i - 1], &a[i]);
				exchange = 1;
			}
		}

		if (exchange == 0)//一趟下来exchange的值还为0,证明就没有发生交换,也就是已经有序
		{
			break;
		}
	}
}

1.3冒泡排序的特性总结

1. 冒泡排序是一种非常容易理解的排序
2. 时间复杂度: O(N^2)   最坏O(N^) 、最好O(N)
3. 空间复杂度: O(1)
4. 稳定性:稳定


2.快速排序👑

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法。
其基本思想为: 任取待排序元素序列中 的某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值,右 子序列中所有元素均大于基准值,然后最左右子序列重复该过程,直到所有元素都排列在相应位置上为止

2.1hoare版本实现思想


排序前

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言


排序中

①先选出一个基准值key(一般是最左边或者最右边) 

②然后右边【L】先走找比key小的值,找到了就停下,然后再左边找比key大的值,找到了也停下

③然后交换这两个数
经过上面三步,就动图就变成了下面的样子

🥇

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

🥈

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言


排序后

由于是一个一个先走一个后走,肯定会出现相遇的时候,相遇就停下来。相遇后将相遇坐标的值和基准值key交换,这时就完成了单趟的hoare排序


【这时的key其实就是在正确的位置上了】


相遇时如下图

🥉

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言


2.2hoare版本快排源代码

void QuickSort(int* a, int begin, int end)
{
	// 区间不存在,或者只有一个值则不需要在处理
	if (begin >= end)
	{
		return;
	}

	int left = begin, right = end;
	int keyi = left;
	while (left < right)
	{
		// 右边先走,找小
		while (left < right && a[right] >= a[keyi])
		{
			--right;
		}

		// 左边再走,找大
		while (left < right && a[left] <= a[keyi])
		{
			++left;
		}

		Swap(&a[left], &a[right]);
	}

	Swap(&a[keyi], &a[left]);
	keyi = left;

	// [begin, keyi-1] keyi [keyi+1, end]
	QuickSort(a, begin, keyi - 1);
	QuickSort(a, keyi+1, end);
}

2.3分析先走

为什么左边做key,右边先走。
右边做key,左边先走。
这样就可以保证相遇位置的值小余或者等于key

我这边拿左边做key,右边先走的情况来讲解。

情况1🥇

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

 这个情况比较好理解,就是上面最后相遇位置的值,也就是3,比6要小


情况2🥈

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

 这个情况如下图所示

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

这边也可以去画一下左边做key,左边先走的情况,会发现相遇位置的值不能保证比key要小



如果觉得文章不错,期待你的一键三连哦,你个鼓励是我创作的动力之源,让我们一起加油,顶峰相见!!!

【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】,数据结构,数据结构,排序算法,算法,c语言

                                         🥇下期预告:快排的其他版本和非递归版本🥇文章来源地址https://www.toymoban.com/news/detail-568256.html

到了这里,关于【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构】 七大排序详解(贰)——冒泡排序、快速排序、归并排序

    ==冒泡排序(Bubble Sort)==也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会

    2024年02月09日
    浏览(123)
  • 数据结构——七大排序[源码+动图+性能测试]

    本章代码gitee仓库:排序 我们日常打扑克牌,摸牌,让后将牌按顺序插入好,这其实就是插入排序的过程,打小插入排序的思想就植入我们的脑海 第一张牌不用管,直接拿在手里,之后的牌按照大小再一个一个插入即可 直接插入排序特性: 越接近有序,效率越高(不用那么多

    2024年02月09日
    浏览(49)
  • 【数据结构】 七大排序详解(壹)——直接插入排序、希尔排序、选择排序、堆排序

    排序 :所谓排序,就是使一串记录,按照其中的某个或某些的大小,递增或递减的排列起来的操作。 稳定性 :假定在待排序的记录序列中,存在多个具有相同的的记录,若经过排序,这些记录的相对次序保持不变,即在原序列中,r[i]=r[j],且r[i]在r[j]之前,而

    2024年02月09日
    浏览(67)
  • 【数据结构】用Java实现七大排序算法

    目录 🌷1. 排序的概念及引用 1.1 排序的概念 1.2 衡量指标 1.2 十个排序算法  1.3 十个排序性能对比 🌷2. 冒泡排序 2.1 算法描述 2.2 动图 ⭐️代码优化 🌷3. 选择排序 3.1 算法描述 3.2 动图  3.3 代码 🌷4. 插入排序 4.1 算法描述 4.2 动图  4.3 代码 🌷5 希尔排序 5.1 描述 5.2 动图  

    2023年04月23日
    浏览(54)
  • 数据结构中的七大排序(Java实现)

    目录 一、直接插入排序 二、希尔排序 三、直接选择排序 四、堆排序 五、冒泡排序 六、快速排序 七、归并排序               定义i下标之前的元素全部已经有序 ,遍历一遍要排序的数组,把i下标前的元素全部进行排序,当遍历玩这个数组后,就已经排好序了。        

    2024年02月08日
    浏览(52)
  • 数据结构:手撕图解七大排序(含动图演示)

    插入排序分为直接插入排序和希尔排序,其中希尔排序是很值得学习的算法 希尔排序的基础是直接插入排序,先学习直接插入排序 直接插入排序类似于打扑克牌前的整牌的过程,假设我们现在有2 4 5 3四张牌,那么应该怎么整牌? 方法很简单,把3插到2和4中间,这样就完成了

    2024年02月15日
    浏览(51)
  • 数据结构与算法中的七大排序(Java实现)

    目录 一、直接插入排序 二、希尔排序 三、直接选择排序 四、堆排序 五、冒泡排序 六、快速排序 七、归并排序               定义i下标之前的元素全部已经有序 ,遍历一遍要排序的数组,把i下标前的元素全部进行排序,当遍历玩这个数组后,就已经排好序了。        

    2024年02月06日
    浏览(58)
  • 【数据结构】详解七大排序算法(直接插入排序、希尔排序、直接选择排序、堆排序、冒泡排序、快速排序)

    1、基本思想    把待排序的数按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所以的记录插入完为止,得到一个新的有序序列。    实际中我们玩扑克牌时,就用到了插入排序的思想 基本步骤:    当插入第i个元素时,前面的arr[0]、arr[2]…arr

    2024年02月04日
    浏览(76)
  • 【数据结构 — 排序 — 交换排序】

    基本思想:所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置,交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。 2.1.算法讲解 以下只讲解冒泡排序代码的简单实现 ,想要更详细的了解冒泡排序

    2024年02月04日
    浏览(44)
  • 【数据结构】排序之交换排序(冒泡 | 快排)

    在之前的博客中介绍了插入排序,有需要的可以点这个链接: link,这次来介绍交换排序,包括冒泡和快排。 话不多说,正文开始。 基本思想 :所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置。 交换排序的特点是:将键值较大的记录向序

    2024年02月03日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包