
快速排序算法步骤:
- 从数列中挑出一个元素,称为 “基准”(pivot);
- 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition) *** 作;
- 递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序;
#include "stdio.h"
void quickSort(int *p, int left, int right)
{
if (left >= right)
return;
int pivot = p[left];
int i = left, j = right;
while (i < j)
{
while (i < j && p[j] > pivot)
j--;
p[i] = p[j];
while (i < j && p[i] < pivot)
i++;
p[j] = p[i];
}
p[i] = pivot;
quickSort(p, left, i-1);
quickSort(p, i+1, right);
}
int main()
{
int lst[10] = {5,3,2,1,4,7,6,10,9,8};
quickSort(lst, 0, 9);
for (int i=0; i<10; i++)
printf("%d ", lst[i]);
return 0;
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)