排序算法时间测试比较

之前介绍过常见的排序算法,可以查看这里

之前实现的代码都是针对int型的算法,现在我将代码改写成了模板,这样可以应用于常见的一些类型。

为了测试比较不同的排序算法,采用了两种计时方式。注意,下面的两段代码中,void(*_sort[])(T*,int) 是函数指针数组。

1. 采用clock函数,统计排序算法所使用的时钟数

代码如下: 

template <class T>
void clock_test()
{
    void(*_sort[])(T*,int)={insert_sort,binary_insert_sort,shell_sort,shell_sort2,select_sort,
                           select_sort2,select_sort3,heap_sort,bubble_sort,bubble_sort2,quick_sort,
                           merge_sort,merge_sort2,merge_sort3,merge_sort4,rank_sort,rank_sort2};
    int len=sizeof(_sort)/sizeof(_sort[0]);
    clock_t start,finish;
    //    cout<<CLOCKS_PER_SEC<<endl;
    cout<<"鐩存帴鎻掑叆\t鎶樺崐鎻掑叆\t甯屽皵鎺掑簭\t"<<endl;
    int step=100;
    for(int k=100;k<=100000;k+=step)
    {
        const int N=k;
        T arr[N];
        double tm[N];
        //    srand(time(0));
        for(int i=0;i<N;i++)
            arr[i]=rand()%1000;
        for(int i=0;i<len;i++) {
            start=clock();
            _sort[i](arr,N);
            finish=clock();
            tm[i]=(finish-start)*1.0/CLOCKS_PER_SEC;
        }
        cout<<k<<'\t';
        for(int i=0;i<len;i++)
            cout<<tm[i]<<'\t';
        cout<<endl;
    }
}

部分测试输出如下: 

 

2. 利用ftime函数,具体介绍见这儿

代码如下:

template <class T>
void time_test()
{
    void(*_sort[])(T*,int)={insert_sort,binary_insert_sort,shell_sort,shell_sort2,select_sort,
                           select_sort2,select_sort3,heap_sort,bubble_sort,bubble_sort2,quick_sort,
                           merge_sort,merge_sort2,merge_sort3,merge_sort4,rank_sort,rank_sort2};
    int len=sizeof(_sort)/sizeof(_sort[0]);
    struct TIMEB ts1,ts2;
    time_t t_sec,t_ms,ti;
    cout<<"鐩存帴鎻掑叆\t鎶樺崐鎻掑叆\t甯屽皵鎺掑簭\t"<<endl;
    int step=100;
    for(int k=100;k<=100000;k+=step)
    {
        const int N=k;
        T arr[N];
        double tm[N];
        for(int i=0;i<N;i++)
            arr[i]=rand()%1000;
        cout<<k<<'\t';
        for(int i=0;i<len;i++) {
            ftime(&ts1);
            _sort[i](arr,N);
            ftime(&ts2);
            t_sec=ts2.time-ts1.time;
            t_ms=ts2.millitm-ts1.millitm;
            ti=t_sec*1000+t_ms;
            cout<<ti<<'\t';
        }
        cout<<endl;
    }
}

部分测试输出如下:

 

最终的全部代码如下:

View Code
#include <iostream>
#include <iterator>
#include <algorithm>
#include <ctime>
#include <cstdlib>
#include <cstdio>
#include <vector>
#include <list>
#include <sys/timeb.h>
#define TIMEB timeb
#define _FUNC cout<<__FUNCTION__<<endl
#define print(arr,n) copy(arr,arr+n,ostream_iterator<T>(cout," "));\
    cout<<endl;
using namespace std;
const char *const red = "\033[0;40;31m";
const char *const green= "\033[0;40;32m";
const char *const normal = "\033[0m";

template <class T>
void insert_sort(T a[],int n)
{
    for(int i=1;i<n;i++) {
        T t=a[i];
        int j;
        for(j=i-1;j>=0&&a[j]>t;j--) {
                a[j+1]=a[j];
        }
        a[j+1]=t;
    }

}
template <class T>
void binary_insert_sort(T a[],int n){
    for(int i=1;i<n;i++){
        int low=0;
        int high=i-1;
        T t=a[i];
        int mid;
        while(low<=high){
            mid=(low+high)/2;
            if(t<a[mid])
                high=mid-1;
            else
                low=mid+1;
        }
        for(int j=i;j>mid;j--)
            a[j]=a[j-1];
        a[low]=t;

    }
}
template <class T>
void shell_sort(T a[],int n)
{
    int gap=n/2;
    bool flag=true;
    while(gap>1||flag)
    {
        flag=false;
        for(int i=0;i+gap<n;i++)
            if(a[i]>a[i+gap])
            {
                swap(a[i],a[i+gap]);
                flag=true;
            }
        if(gap>1)
            gap/=2;
    }

}
template <class T>
void shell_sort2(T a[],int n){
    int gap=n/2;
    while(gap>0){
        for(int i=gap;i<n;i++){
            T t=a[i];
            int j;
            for(j=i-gap;j>=0&&a[j]>t;j-=gap)
                a[j+gap]=a[j];
            a[j+gap]=t;
        }
        gap/=2;
    }
}
template <class T>
void select_sort(T a[],int n)
{
    for(int i=0;i<n-1;i++)
    {
        T min=a[i];
        int index=i;
        for(int j=i+1;j<n;j++)
            if(a[j]<min)
            {
                min=a[j];
                index=j;
            }
        swap(a[i],a[index]);
    }
}
template <class T>
void select_sort2(T a[],int n)
{
    for(int i=n-1;i>0;i--){
        for(int j=0;j<i;j++)
            if(a[j]>a[i])
                swap(a[j],a[i]);
    }

}
template <class T>
void select_sort3(T a[],int n)
{
    bool flag=true;
    for(int i=n-1;i>0&&flag;i--){
        flag=false;
        for(int j=0;j<i;j++)
            if(a[j]>a[i])
                swap(a[j],a[i]),flag=true;
    }

}
template <class T>
void adjust(T b[],int m,int n){
    int j=m;
    int k=2*m;
    while(k<=n){
        if(k<n&&b[k]<b[k+1])
            k++;
        if(b[j]<b[k])
            swap(b[j],b[k]);
        j=k;
        k*=2;
    }
}
template <class T>
void heap_sort(T a[],int n){
    T *b=a-1;
    for(int i=n/2;i>=1;i--)
        adjust(b,i,n);
    for(int i=n-1;i>=1;i--){
        swap(b[1],b[i+1]);
        adjust(b,1,i);
    }
}
template <class T>
void bubble_sort(T a[],int n)
{
    for(int i=n-1;i>0;i--)
        for(int j=0;j<i;j++)
            if(a[j]>a[j+1])
                swap(a[j],a[j+1]);

}
template <class T>
void bubble_sort2(T a[],int n)
{
    bool flag=true;
    for(int i=n-1;i>0&&flag;i--){
        flag=false;
        for(int j=0;j<i;j++)
            if(a[j]>a[j+1])
                swap(a[j],a[j+1]),flag=true;
    }

}
template <class T>
void qsort(T a[],int l,int r){
    T pvt=a[(l+r)/2];
    int i=l,j=r;
    while(i<=j){
        while(a[i]<pvt)
            i++;
        while(a[j]>pvt)
            j--;
        if(i<=j){
            if(i!=j)
                swap(a[i],a[j]);
            i++;
            j--;
        }
    }
    if(j>l)
        qsort(a,l,j);
    if(i<r)
        qsort(a,i,r);
}
template <class T>
void quick_sort(T a[],int n){
    qsort(a,0,n-1);
}
template <class T>
void merge(T a[],T b[],int l,int m,int r){
    int i,j,k;
    i=l;
    j=m+1;
    k=l;
    while(i<=m&&j<=r){
        if(a[i]<a[j])
            b[k++]=a[i++];
        else
            b[k++]=a[j++];
    }
    while(i<=m)
        b[k++]=a[i++];
    while(j<=r)
        b[k++]=a[j++];
    for(int s=l;s<=r;s++)
        a[s]=b[s];
}
template <class T>
void msort(T a[],T b[],int l,int r){
    if(l<r){
        int m=(l+r)/2;
        msort(a,b,l,m);
        msort(a,b,m+1,r);
        merge(a,b,l,m,r);
    }
}
template <class T>
void merge_sort(T a[],int n){
    T *b=new T[n];
    msort(a,b,0,n-1);
    delete[] b;
}
template <class T>
void merge_pass(T x[],T y[],int s,int n){
    int i=0;
    while(i+2*s-1<n){
        merge(x,y,i,i+s-1,i+2*s-1);
        i+=2*s;
    }
    if(i+s<n)
        merge(x,y,i,i+s-1,n-1);
    else
        for(int j=i;j<=n-1;j++)
            y[j]=x[j];
}
template <class T>
void merge_sort2(T a[],int n){
    T *b=new T[n];
    int s=1;
    while(s<n){
        merge_pass(a,b,s,n);
        s+=s;
        merge_pass(b,a,s,n);
        s+=s;
    }
    delete[] b;
}

template <class T>
void merge_sort3(T a[],int n){
    vector<int> st;
    for(int i=0;i<n-1;i++){
        if(a[i]>a[i+1])
            st.push_back(i);
    }
    st.push_back(n-1);
    T *b=new T[n];
    int l,m,r;
    l=0;
    if(!st.empty())
    {
        m=st.front();
        st.erase(st.begin());
    }
    while(!st.empty()){
        r=st.front();
        st.erase(st.begin());
        merge(a,b,l,m,r);
        m=r;
    }
    delete [] b;
}
template <class T>
void merge_sort4(T a[],int n){
    int *pos=new int[n];
    int k=0;
    for(int i=0;i<n-1;i++){
        if(a[i]>a[i+1])
            pos[k++]=i;
    }
    pos[k++]=n-1;
    T *b=new T[n];
    int l,m,r;
    l=0;
    int p=0;
    if(p<k)
        m=pos[p++];
    while(p<k){
        r=pos[p++];
        merge(a,b,l,m,r);
        m=r;
    }
    delete [] b;
}
template <class T>
void rank(T arr[],int n,int r[])
{
    for(int i=0;i<n;i++)
        r[i]=0;
    for(int i=1;i<n;i++){
        for(int j=0;j<i;j++)
        {
            if(arr[j]<=arr[i])
                r[i]++;
            else
                r[j]++;
        }
    }
}
template <class T>
void rank_sort(T arr[],int n)
{
    int *r=new int[n];
    rank(arr,n,r);
    for(int i=0;i<n;i++)
    {
        while(r[i]!=i)
        {
            T t=r[i];
            swap(arr[i],arr[t]);
            swap(r[i],r[t]);
        }
    }
    delete[] r;
}
template <class T>
void rank_sort2(T a[],int n){
    int *r=new int[n];
    rank(a,n,r);
    T *u=new T[n];
    for(int i=0;i<n;i++)
        u[r[i]]=a[i];
    for(int i=0;i<n;i++)
        a[i]=u[i];
    delete[] r;
    delete[] u;
}
int maxbits(int a[],int n){
    int d=0;
    for(int i=0;i<n;i++){
        int b=1;
        int r=a[i];
        while(r/10>0){
            b++;
            r/=10;
        }
        if(d<b)
            d=b;
    }
    return d;
}
void radix_sort(int a[],int n){
    int d=maxbits(a,n);
    int *temp=new int[n];
    int *count=new int[10];
    int adix=1;
    for(int b=1;b<=d;b++){
        for(int i=0;i<10;i++)
            count[i]=0;
        for(int i=0;i<n;i++){
            int k=(a[i]/adix)%10;
            count[k]++;
        }
        for(int i=1;i<10;i++)
            count[i]+=count[i-1];
        for(int i=n-1;i>=0;i--){
            int k=(a[i]/adix)%10;
            count[k]--;
            temp[count[k]]=a[i];
        }
        for(int i=0;i<n;i++)
            a[i]=temp[i];
        adix*=10;
    }
    delete[] temp;
    delete[] count;
}
void radix_sort2(int a[],int n){
    int bits=maxbits(a,n);
    list<int> x(a,a+n);
    int range=10;
    vector<list<int> > bin(range);
    list<int> y;
    list<int>::iterator ite;
    int adix=1;
    for(int i=0;i<bits;i++){
        for(ite=x.begin();ite!=x.end();ite++){
            int d=(*ite/adix)%10;
            bin[d].push_back(*ite);
        }   
        vector<list<int> >::iterator ite2;
        y.clear();
        for(ite2=bin.begin();ite2!=bin.end();++ite2){
            for(ite=ite2->begin();ite!=ite2->end();++ite)
                y.push_back(*ite);
            ite2->clear();
        }
        x=y;
        adix*=10;
    }
    int i=0;
    for(ite=x.begin();ite!=x.end();ite++)
        a[i++]=*ite;
}
template <class T>
void sort_test(void (*_sort)(T*,int)){
    const int N=10;
    T orig[N];
    T standard[N];
    T arr[N];
    srand(time(0));
    for(int j=0;j<18;j++){
        for(int i=0;i<N;i++)
            orig[i]=rand()%100;
        cout<<"bef:";
        print(orig,N);

        copy(orig,orig+N,standard);
        sort(standard,standard+N);
        cout<<"std:";
        print(standard,N);

        copy(orig,orig+N,arr);
        _sort(arr,N);
        cout<<"aft:";
        print(arr,N);
        if(equal(standard,standard+N,arr))
            printf("%sOK%s\n",green,normal);
        else
            printf("%sNO%s\n",red,normal);
    }

}
template <class T>
void clock_test()
{
    void(*_sort[])(T*,int)={insert_sort,binary_insert_sort,shell_sort,shell_sort2,select_sort,
                           select_sort2,select_sort3,heap_sort,bubble_sort,bubble_sort2,quick_sort,
                           merge_sort,merge_sort2,merge_sort3,merge_sort4,rank_sort,rank_sort2};
    int len=sizeof(_sort)/sizeof(_sort[0]);
    clock_t start,finish;
    //    cout<<CLOCKS_PER_SEC<<endl;
    cout<<"鐩存帴鎻掑叆\t鎶樺崐鎻掑叆\t甯屽皵鎺掑簭\t"<<endl;
    int step=100;
    for(int k=100;k<=100000;k+=step)
    {
        const int N=k;
        T arr[N];
        double tm[N];
        //    srand(time(0));
        for(int i=0;i<N;i++)
            arr[i]=rand()%1000;
        for(int i=0;i<len;i++) {
            start=clock();
            _sort[i](arr,N);
            finish=clock();
            tm[i]=(finish-start)*1.0/CLOCKS_PER_SEC;
        }
        cout<<k<<'\t';
        for(int i=0;i<len;i++)
            cout<<tm[i]<<'\t';
        cout<<endl;
    }
}
template <class T>
void time_test()
{
    void(*_sort[])(T*,int)={insert_sort,binary_insert_sort,shell_sort,shell_sort2,select_sort,
                           select_sort2,select_sort3,heap_sort,bubble_sort,bubble_sort2,quick_sort,
                           merge_sort,merge_sort2,merge_sort3,merge_sort4,rank_sort,rank_sort2};
    int len=sizeof(_sort)/sizeof(_sort[0]);
    struct TIMEB ts1,ts2;
    time_t t_sec,t_ms,ti;
    cout<<"鐩存帴鎻掑叆\t鎶樺崐鎻掑叆\t甯屽皵鎺掑簭\t"<<endl;
    int step=100;
    for(int k=100;k<=100000;k+=step)
    {
        const int N=k;
        T arr[N];
        double tm[N];
        for(int i=0;i<N;i++)
            arr[i]=rand()%1000;
        cout<<k<<'\t';
        for(int i=0;i<len;i++) {
            ftime(&ts1);
            _sort[i](arr,N);
            ftime(&ts2);
            t_sec=ts2.time-ts1.time;
            t_ms=ts2.millitm-ts1.millitm;
            ti=t_sec*1000+t_ms;
            cout<<ti<<'\t';
        }
        cout<<endl;
    }
}
int main()
{
//    sort_test(radix_sort2);
//    clock_test<int>();
    time_test<int>();
}

 

 

 

 


 

posted @ 2012-07-02 01:10  Mr.Rico  阅读(1755)  评论(0编辑  收藏  举报