14种排序

#include<iostream>
#include<time.h>
using namespace std;
/*
简单插入排序:
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Insertion_Sort(int *a,int n)
{
    int i,j;
    for(i=2;i<=n;i++)
        if(a[i]<a[i-1])
        {
            a[0]=a[i];
            for(j=i-1;a[j]>a[0];j--)
                a[j+1]=a[j];
            a[j+1]=a[0];
        }
}
/*
折半插入排序:
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Bin_Sort(int *a,int n)
{
    int i,j,low,mid,high;
    for(i=2;i<=n;i++)
        if(a[i]<a[i-1])
        {
            a[0]=a[i];
            low=1;
            high=i-1;
            while(low<=high)
            {
                mid=(low+high)/2;
                if(a[mid]>a[0])
                    high=mid-1;
                else 
                    low=mid+1;
            }
            for(j=i-1;j>high;j--)
                a[j+1]=a[j];
            a[high+1]=a[0];
        }
}
/*选择排序:
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Selection_Sort(int *a,int n)
{
    int i,j,k;
    for(i=1;i<n;i++)
    {
        k=i;
        for(j=i+1;j<=n;j++)
            if(a[k]>a[j])
                k=j;
        if(k!=i)    
            swap(a[k],a[i]);
    }
}
/*快速排序
最差时间复杂度:O(n^2)
平均时间复杂度:O(nlogn)
*/
void Quick_Sort(int *a,int low,int high)
{
    int i=low,j=high;
    a[0]=a[low];
    while(low<high)
    {
        while(low<high && a[high]>=a[0])
            high--;
            swap(a[low],a[high]);
        while(low<high && a[low]<=a[0])
            low++;
            swap(a[low],a[high]);
    }
    a[low]=a[0];
    if(i!=low)
        Quick_Sort(a,i,low-1);
    if(j!=high)
        Quick_Sort(a,high+1,j);
}
/*冒泡排序
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Bubble_Sort(int *a,int n)
{
    int i;
    bool change=true;
    while(change)
    {
        change=false;
        for(i=1;i<n;i++)
            if(a[i]>a[i+1])
            {
                change=true;
                swap(a[i],a[i+1]);
            }
    }
}
/*鸡尾酒排序(双向冒泡排序):
最差时间复杂度:O(n^2))
平均时间复杂度:O(n^2)
*/
void Cocktail_Sort(int *a,int n)
{
    int i;
    int left=1,right=n;
    bool change=true;
    while(change)
    {
        change=false;
        for(i=left;i<right;i++)
            if(a[i]>a[i+1])
            {
                change=true;
                swap(a[i],a[i+1]);
            }
            right--;
        for(i=right;i>left;i--)
            if(a[i]<a[i-1])
            {
                change=true;
                swap(a[i],a[i-1]);
            }
            left++;
    }
}
/*堆排序
最差时间复杂度:O(nlogn)
平均时间复杂度:O(nlogn)
*/
void Heap_Adjust(int *a,int low,int high)
{
    int i;
    a[0]=a[low];
    for(i=2*low;i<=high;i*=2)
        {
            if(i<high && a[i]<a[i+1])
                i++;
            if(a[0]>=a[i])
                break;
            else 
            {
                a[low]=a[i];
                low=i;
            }
        a[low]=a[0];
        }
}
void Heap_Sort(int *a,int n)
{
    int i;
    for(i=n/2;i>=1;i--)
        Heap_Adjust(a,i,n);
    for(i=n;i>=2;i--)
    {
        swap(a[1],a[i]);
         Heap_Adjust(a,1,i-1);
    }
}
/*
希尔排序
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^1.3)
*/
void Shell_Sort(int *a,int n)
{
    int i,j;
    int gap=n/2;
    while(gap)
    {
        for(i=gap+1;i<=n;i++)
            if(a[i]<a[i-gap])
            {
                a[0]=a[i];
                for(j=i-gap;j>0 && a[j]>a[0];j-=gap)
                    a[j+gap]=a[j];
                a[j+gap]=a[0];
            }
            gap/=2;
    }
}
/*
计数排序:
最差时间复杂度:O(n+k)
平均时间复杂度:O(n+k)
*/
void Counting_Sort(int *a,int n)
{
    int i;
    int max=a[1];
    for(i=2;i<=n;i++)
        {
            if(max<a[i])
            max=a[i];
        }
    int *mark=new int[max+1];
    memset(mark,0,sizeof(int)*(max+1));
    for(i=1;i<=n;i++)
        mark[a[i]]++;
    for(i=1;i<=max;i++)
        mark[i]+=mark[i-1];
    int *p=new int[n+1];
    memset(p,0,sizeof(int)*(n+1));
    for(i=1;i<=n;i++)
        {
            p[mark[a[i]]]=a[i];
            mark[a[i]]--;
        }
    for(i=1;i<=n;i++)
        a[i]=p[i];
}
/*
鸽巢排序:
最差时间复杂度:O(n+N)
平均时间复杂度:O(n+N)
*/
void Pigeonhole_Sort(int *a,int n)
{
    int i,j,k=1;
    int max=a[1];
    for(i=2;i<=n;i++)
        {
            if(max<a[i])
            max=a[i];
        }
    int *mark=new int[max+1];
    memset(mark,0,sizeof(int)*(max+1));
    for(i=1;i<=n;i++)
        mark[a[i]]++;
    for(i=1;i<=max;i++)
    for(j=1;j<=mark[i];j++)
        a[k++]=i;
}
/*
归并排序:
最差时间复杂度:O(nlogn)
平均时间复杂度:O(nlogn)
*/
void Merge(int *a,int low,int mid,int high)
{
    int p,i=low,j=mid+1,k=low;
    int *temp=new int[high+1];
    memset(temp,0,sizeof(int)*(high+1));
    for(;i<=mid && j<=high;k++)
        if(a[i]<a[j])
            temp[k]=a[i++];
        else 
            temp[k]=a[j++];
    if(i<=mid)
        for(p=0;p<=mid-i;p++)
            temp[k+p]=a[i+p];
    if(j<=high)
        for(p=0;p<=high-j;p++)
            temp[k+p]=a[j+p];
    for(p=low;p<=high;p++)
        a[p]=temp[p];
}
void MSort(int *a,int low,int high)
{
    if(low<high)
    {
        int mid=(low+high)/2;
        MSort(a,low,mid);
        MSort(a,mid+1,high);
        Merge(a,low,mid,high);
    }
}
/*
梳排序:
最差时间复杂度:O(nlogn)
平均时间复杂度:O(nlogn)
*/
void Comb_Sort(int *a,int n)
{
    int i;
    int gap=n;
    while(gap/=1.3)
    {
        for(i=gap+1;i<=n;i++)
            if(a[i]<a[i-gap])
                swap(a[i],a[i-gap]);
    }
}
/*
奇偶排序(砖排序):
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Odd_Even(int *a,int n)
{
    int i;
    bool change=true;
    while(change)
    {
        change=false;
    for(i=1;i<n;i+=2)
        if(a[i]>a[i+1])
            {
                change=true;
                swap(a[i],a[i+1]);
            }
    for(i=2;i<n;i+=2)
        if(a[i]>a[i+1])
        {
            change=true;
            swap(a[i],a[i+1]);
        }
    }
}
/*
地精排序(侏儒排序):
最差时间复杂度:O(n^2)
平均时间复杂度:O(n^2)
*/
void Gnome_Sort(int *a,int n)
{
    int i=0;
    while(i<n)
    {
        if(i<=0 || (i>=1 && a[i]<=a[i+1]))
            i++;
        else 
        {
            swap(a[i],a[i+1]);
            i--;
        }
    }
}
void Out(int *a,int n)
{
    int i;
    for(i=1;i<=n;i++)
        cout<<a[i]<<" ";
    cout<<endl;
}
int main()
{
    srand((unsigned)time(NULL));
    int *p=new int[16];
    memset(p,0,sizeof(int)*16);
    for(int i=1;i<=15;i++)
    {
        p[i]=rand()%100;
    }
    Out(p,15);
    //Insertion_Sort(p,15);
    //Bin_Sort(p,15);
    //Selection_Sort(p,15);
    //Quick_Sort(p,1,15);
    //Bubble_Sort(p,15);
    //Cocktail_Sort(p,15);
    //Heap_Sort(p,15);
    //Shell_Sort(p,15);
    //Counting_Sort(p,15);
    //Pigeonhole_Sort(p,15);
    //Comb_Sort(p,15);
    //Odd_Even(p,15);
    //MSort(p,1,15);
    Gnome_Sort(p,15);
    Out(p,15);
}

 

posted @ 2013-12-31 15:49  博园少主  阅读(173)  评论(0编辑  收藏  举报