问题描述
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
第一行为一个整数n。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9
冒泡排序
冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。
它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从A到Z)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素已经排序完成。
实质:把小(大)的元素往前(后)调
冒泡排序算法的原理如下:
#include
int main()
{
unsigned int n,i,j,t;
scanf("%d",&n);
int P[n];
for(i=0;i<=n-1;i++)
{
scanf("%d",&P[i]);
}
for(j=n;j>=1;j--)
{
for(i=0;iP[i+1])
{
t=P[i+1];
P[i+1]=P[i];
P[i]=t;
}
}
for(i=0;i<=n-1;i++)
{
printf("%d",P[i]);
printf(" ");
}
return 0;
}
选择排序
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到全部待排序的数据元素排完。 选择排序是不稳定的排序方法。
思想
n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果:
#include
int main()
{
int i,j,n,a[205],t,temp;
scanf("%d",&n);
for(i=0;ia[j])
{
a[i]=a[j];
t=j;
}
}
if(t
插入排序
插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
插入排序的基本思想是:每步将一个待排序的记录,按其关键码值的大小插入前面已经排序的文件中适当位置上,直到全部插入完为止。包括:直接插入排序,二分插入排序(又称折半插入排序)。
代码
#include
void Sort(int *a,int n)
{ //插入排序
int i,j,temp,k;
for(i=1;i=0&&a[j]>temp;j--)
{
a[j+1] = a[j];
}
a[j+1] = temp;
}
}
int main()
{
int n,*a;
scanf("%d",&n);
a = new int[n];
for(int i=0;i
快速排序
快速排序(Quicksort)是对冒泡排序的一种改进。
快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
快速排序思想:
代码
#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;
}
Sort排序
用于C++中,对给定区间所有元素进行排序。头文件是#include 。
为什么要用c++标准库里的排序函数
Sort()函数是c++一种排序方法之一,学会了这种方法也打消我学习c++以来使用的冒泡排序和选择排序所带来的执行效率不高的问题!因为它使用的排序方法是类似于快排的方法,时间复杂度为n*log2(n),执行效率较高!
c++标准库里的排序函数的使用方法
I)Sort函数包含在头文件为#include的c++标准库中,调用标准库里的排序方法可以不必知道其内部是如何实现的,只要出现我们想要的结果即可!
II)Sort函数有三个参数:
(1)第一个是要排序的数组的起始地址。
(2)第二个是结束的地址(最后一位要排序的地址的下一地址)
(3)第三个参数是排序的方法,可以是从大到小也可是从小到大,还可以不写第三个参数,此时默认的排序方法是从小到大排序。
Sort函数使用模板:
Sort(start,end,排序方法)
代码
#include
#include //专属头文件
using namespace std;
int main()
{
int n,i,a[202];
cin>>n;
for(i=0;i>a[i];
sort(a,a+n);//核心排序语句,默认从小到大;
for(i=0;i
运算结果