蓝桥杯 基础练习 数列排序(4)之快排

  基础练习 数列排序  
时间限制:1.0s   内存限制:512.0MB
问题描述
  给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
  第一行为一个整数n。
  第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
  输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9

总结,采用本题练习快速排序,时间复杂度O(log2n),竞赛时直接冒泡、选择排序即可。

#include 

//划分——每次划分唯一确定一个元素位置
int Partition(int A[], int low, int high)
{
	int pivot = A[low];  //一般采用严蔚敏教材版本,以第一个位置为基准

	while (low < high)
	{
		while (low < high && A[high] >= pivot)
		{
			--high;
		}
		A[low] = A[high];  //将比基准小的元素移动到左端

		while (low < high && A[low] <= pivot)
		{
			++low;
		}
		A[high] = A[low];  //将比基准小的元素移动到右端
	}
	A[low] = pivot;

	return low;
}

//快排——平均时间复杂度O(log2n)
void QuickSort(int A[], int low, int high)
{
	int pivotpos;

	if (low < high)
	{
		pivotpos = Partition(A,low,high);
		//依次对划分后的子表递归排序
		QuickSort(A,low,pivotpos-1);
		QuickSort(A,pivotpos+1,high);
	}
}

int main(void)
{

	int i, n, A[200];

	while (scanf("%d",&n) != EOF)  
	{
		for (i = 0; i < n; ++i)
		{
			scanf("%d",&A[i]);
		}
		QuickSort(A,0,n-1);
	
		//打印
		for (i = 0; i < n; ++i)
		{
			printf("%d ",A[i]);
		}
		printf("\n");
	}

	return 0;
}

Copyright © 2017 KINGDOM. All rights reserved.

你可能感兴趣的:(ACM,Data,Structure)