三大排序
一.快排实现 sort(bigin,end) 复杂度 nlogn 每一层n复杂度,logn层
#include<cstdio>
#include<algorithm>
#include<time.h>
using namespace std;
void Sort(int *a,int l,int r)
{
int k = 0;
int len = l - r;
if(len <= 1) return ;
srand(time(NULL));
int pos = rand()%len;
swap(a[r-1],a[pos+l]);
for(int i = l; i < r; i++){
if(a[i] >a[r-1]){
swap(a[i],a[l+k]);
k++;
}
}
Sort(a,l,l+k-1);
Sort(a,l+k,r);
}
二.桶排序 速度快但不适用于太大的数 复杂度nlogn
#include<cstdio>
#include<cstring>
const int maxn = 2222222;
int p[maxn],w[maxn],a[maxn];
void Sort(int *a,int n, int mx){
for(int i = 1; i <= mx ; i++){
w[i] = 0;
}
for(int i = 1; i <= n; i++){
w[a[i]]++;
}
for(int i = 1; i <= mx;i++){
w[i]+=w[i-1];
}
for(int i =1; i <= n; i++){
p[i] = w[a[i]]--;
}
for(int i =1; i <= n ; i++){
w[p[i]] = i;
}
}
int main(){
int n,mx = 0 ;
while(~scanf("%d", &n)){
for(int i = 1; i <= n ; i++){
scanf("%d", &a[i]);
if(a[i] > mx)
mx = a[i];
}
Sort(a,n,mx);
for(int i = 0; i < n ; i ++){
if(i){
printf(" ");
}
printf("%d", a[w[n-i]]);
}
printf("\n");
}
return 0;
}
三.归并排序 复杂度nlogn
#include<cstdio>
#include<algorithm>
#include<cstdio>
const int maxn = 2222222;
int temp[maxn];
void Merge_Sort(int *a,int l,int r){
int len = r - l;
if(len <= 1) return ;
int mid = l + len/2 - 1;
Merge_Sort(a,l,mid+1);
Merge_Sort(a,mid+1,r);
int p1 = l,p2 = mid + 1;
for(int i = l ; i < r; i++){
if(p1 == mid + 1){
temp[i] = a[p2];
p2++;}
else if(p2 == r){
temp[i] = a[p1];
p1++;
}
else {
if(a[p1] > a[p2]){
temp[i] = a[p1];
p1++;
}
else {
temp[i] = a[p2];
p2++;
}
}
}
for(int i = l ; i < r;i ++)
a[i] = temp[i];
}
int a[maxn];
int main(){
int n;
while(~scanf("%d",&n)&&n){
for(int i = 1; i <= n ; i++)
scanf("%d", &a[i]);
Merge_Sort(a,1,n+1);
for(int i = 1;i < n ; i++)
printf("%d ",a[i]);
printf("%d\n",a[n]);
}
return 0;
}
桶排序和归并排序较稳定