[排序算法] 快速排序 (C++) (含三种写法)

快速排序解释

快速排序 Quick Sort 与归并排序一样,也是典型的分治法的应用。 (如果有对 归并排序还不了解的童鞋,可以看看这里哟~ 归并排序)❤❤❤

快速排序的分治模式

1、选取基准值,获取划分位置。将原数组 a[l, r] 划分为两个子数组 a[l, mid - 1]a[mid + 1, r]。在前一个数组中所有元素都小于等于 a[mid],后一个数组中所有元素都大于等于 a[mid]。而此时的 a[mid] 的值就是我们所取的基准值,mid 就每次划分的位置;

2、递归调用快速排序函数,分别对两个子数组 a[l, mid - 1]a[mid + 1, r] 排序;

3、快速排序我们是在原数组上进行操作的,所以我们并不需要合并,最后 a[l, r] 已经有序。

快速排序的三种写法

快速排序比较普及的有三种写法,分别是 左右指针法 挖坑法前后指针法。主要是取得划分位置实现的方法有所不同
接下来会逐个介绍这三种快速排序的写法。



左右指针法

左右指针法步骤

1、首先 我们一般选取最左边的元素作为基准值 key

2、然后我们需要定义两个变量 ij
其中 i 为左指针(其实不是指针啦,只是为了方便这么叫它

相关文章

背景:计算机内部用补码表示二进制数。符号位1表示负数,0表...
大家好,我们现在来讲解关于加密方面的知识,说到加密我认为不...
相信大家在大学的《算法与数据结构》里面都学过快速排序(Qui...
加密在编程中的应用的是非常广泛的,尤其是在各种网络协议之...
前言我的目标是写一个非常详细的关于diff的干货,所以本文有...
对称加密算法 所有的对称加密都有一个共同的特点:加密和...