排序算法时间测试比较
之前介绍过常见的排序算法,可以查看这里
之前实现的代码都是针对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;
}
}
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;
}
}
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>();
}
#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>();
}