基础练习 数列排序
时间限制:1.0s 内存限制:512.0MB
问题描述
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
第一行为一个整数n。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
8 3 6 4 9
样例输出
3 4 6 8 9
总结,采用本题练习快速排序,时间复杂度O(log2n),竞赛时直接冒泡、选择排序即可。
#include <stdio.h>
//划分——每次划分唯一确定一个元素位置
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.