0
点赞
收藏
分享

微信扫一扫

Quicksort快速排序

凉夜lrs 2022-04-19 阅读 71
  1. 🌴快速排序中心思想
  2. 🌴快速排序操作实现

快速排序中心思想

百度描述->

总结->

基本思想

1选定中心轴
2将大于中心轴的数字放在中心轴的右边
3将小于中心轴的数字放在中心轴的左边
4分别对左右子序列重复前三步操作


快速排序操作实现

这边我就用C语言实现了>>

void Quicksort(int arr[], int L, int R)
{
	if (L >= R)			//设定结束条件
		return;
	int right = R;	//另设变量存储数组的起始位置和末尾
	int left = L;
	int point = arr[L];//选定中心轴
	while (left < right && point <= arr[right])
	{								//在left<right条件下,把比中心轴大的放在右边,小的放在左边
		right--;		//如果本身比中心轴大的数就在中心轴右边,则继续移动right
	}
	if (left < right)	//如果跳出上面循环,则一定是因为right指向的值比中心轴小,则需要把它移动到左边	
	{
		arr[left] = arr[right];
	}
	while (left < right && point > arr[left])
	{
		left++;//如果本身比中心轴小的数就在中心轴左边,则继续移动left
	}
	if (left < right)//同样如果跳出上面循环,则一定是因为left指向的值比中心轴大,则需要把它移动到右边		
	{
		arr[right] = arr[left];
	}
	if (right == left)		//最后两数移动到同一位置,就把刚才选中心轴的数放在这位置上
	{
		arr[right] = point;
	}//上面已经进行一次排序,分成两组,一组比中心轴大,在左边,一组比中心轴小,在右边
	Quicksort(arr, L, right - 1);//递归将左边的进行排序
	Quicksort(arr, right + 1, R);//递归将右边的进行排序
}

调用一下函数

int main()
{
	int arr[10] = { 2,1,4,3,9,6,5,7,8,10 };
	int sz = sizeof(arr) / sizeof(arr[0])-1;
	Quicksort(arr,0,sz);
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

运行结果>
在这里插入图片描述


完事!!

举报

相关推荐

双轴快速排序(Dual Pivot Quicksort)

0 条评论