基本概念
快速排序( Quick Sort)的基本思想是: 通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序的目的。
快速排序算法最早是由图灵奖获得者Tony Hoare设计出来的,他在形式化方法理论以及ALGOL60 编程语言的发明中都有卓越的贡献,是20世纪最伟大的计算机科学家之一。而这快速排序算法只是他众多贡献中的一个小发明而已。
希尔排序相当于直接插入排序的升级,它们同属于插入排序类,堆排序相当于简单选择排序的升级,它们同属于选择排序类。而快速排序其实就是我们前面认为最慢的冒泡排序的升级,它们都属于交换排序类。即它也是通过不断比较和移动交换来实现排序的,只不过它的实现,增大了记录的比较和移动的距离,将关键字较大的记录从前面直接移动到后面,关键字较小的记录从后面直接移动到前面,从而减少了总的比较次数和移动交换次数
具体的实现步骤如下:
- 选择基准元素pivot。
- 设置左指针left指向数组的起始位置,设置右指针right指向数组的末尾位置。
- 移动左指针left,直到找到一个大于等于pivot的元素。
- 移动右指针right,直到找到一个小于等于pivot的元素。
- 如果left小于等于right,则交换left和right指针所指向的元素。
- 重复步骤 3 和 4,直到left大于right。
- 此时,将基准元素pivot与right指针指向的元素交换位置。经过这一步操作,基准元素将位于合适的位置,左边的元素都比pivot小,右边的元素都比pivot大。
- 递归地对基准元素左边的子数组和右边的子数组进行快速排序。
- 递归结束的条件是子数组的大小为1或0,因为只有一个元素或者没有元素时,它们已经是有序的。
视频教程
【秒懂算法快速排序-动画4分钟精讲】 https://www.bilibili.com/video/BV1K44y1k79z/?share_source=copy_web&vd_source=38ed12eb64a70618ffa8e44b3d5eadf6
【全网最清晰快速排序,看完快排思想和代码全部通透,不通透你打我!】 https://www.bilibili.com/video/BV1vP411g7J3/?share_source=copy_web&vd_source=38ed12eb64a70618ffa8e44b3d5eadf6
using System;
class QuickSort
{
static void Main(string[] args)
{
int[] array = { 9, 2, 5, 1, 7, 4, 8, 6, 3 };
Console.WriteLine("Original Array: ");
PrintArray(array);
QuickSortAlgorithm(array, 0, array.Length - 1); // 调用快速排序算法
Console.WriteLine("\nSorted Array: ");
PrintArray(array);
}
static void QuickSortAlgorithm(int[] array, int left, int right)
{
if (left < right)
{
int pivotIndex = Partition(array, left, right); // 获取基准元素的位置
// 递归地对基准元素左边的子数组和右边的子数组进行快速排序
QuickSortAlgorithm(array, left, pivotIndex - 1);
QuickSortAlgorithm(array, pivotIndex + 1, right);
}
}
static int Partition(int[] array, int left, int right)
{
int pivot = array[right]; // 选择最右边的元素作为基准元素
int i = left - 1; // 初始化左指针
for (int j = left; j < right; j++)
{
if (array[j] < pivot)
{
i++;
Swap(array, i, j); // 将小于基准元素的元素放到左边
}
}
Swap(array, i + 1, right); // 将基准元素放到合适的位置
return i + 1; // 返回基准元素的位置
}
static void Swap(int[] array, int i, int j)
{
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
static void PrintArray(int[] array)
{
foreach (int num in array)
{
Console.Write(num + " ");
}
Console.WriteLine();
}
}