快速排序(Quick Sort)是一种高效的排序算法,它选用分治法(Divide and Conquer)的战略来把一个序列分为较小和较大的两个子序列,然后递归地排序这两个子序列。
快速排序的根本过程如下:
1. 挑选基准值(Pivot):从数列中挑出一个元素,作为基准值。2. 切割(Partitioning):重新排列数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准的后边(持平的数能够就任一边)。在这个切割完毕之后,该基准就处于数列的中心方位。这个称为切割(partition)操作。3. 递归排序子序列:递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。
以下是运用C言语完成的快速排序算法:
```cinclude
// 交流两个元素的值void swap { int t = a; a = b; b = t;}
// 切割函数int partition, int low, int highqwe2 { int pivot = arr; // 挑选最终一个元素作为基准 int i = ; // 较小元素的索引
for { // 假如当时元素小于或等于基准 if // 快速排序函数void quickSort, int low, int highqwe2 { if { // pi是切割后基准的索引 int pi = partition;
// 递归地对基准左右两头的子数组进行排序 quickSort; quickSort; }}
// 打印数组函数void printArray, int sizeqwe2 { for printfqwe2; printf;}
// 主函数int main { int arr = {10, 7, 8, 9, 1, 5}; int n = sizeof / sizeofqwe2; quickSort; printf; printArray; return 0;}```
这个程序界说了一个`quickSort`函数,它运用`partition`函数来找到基准的正确方位,并递归地对基准左右两头的子数组进行排序。`main`函数中创建了一个数组,并调用`quickSort`对其进行排序,然后打印出排序后的数组。