快速排序(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`对其进行排序,然后打印出排序后的数组。