C 语言实现快速排序

C 语言实现快速排序,第1张

 快速排序算法步骤:

  1. 从数列中挑出一个元素,称为 “基准”(pivot);
  2. 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition) *** 作;
  3. 递归地(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;
}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1498827.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-25
下一篇2022-06-25

发表评论

登录后才能评论

评论列表(0条)

    保存