现在的位置: 首页 > 综合 > 正文

数据结构 排序算法

2013年10月12日 ⁄ 综合 ⁄ 共 5433字 ⁄ 字号 评论关闭
//============================================================================
// Name        : shuanfa.cpp
// Author      : yuanxiang
// Version     :
// Copyright   : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================

#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <cstring>
#include <windows.h>
#include <sys/timeb.h>
#include <time.h>
using namespace std;


struct timeval
{
long tv_sec;
long tv_usec;
};

int gettimeofday(struct timeval* tv)
{
    union{
             long long ns100;
             FILETIME ft;
    }now;
    GetSystemTimeAsFileTime (&now.ft);
    tv->tv_usec = (long) ((now.ns100 ) % 1000000LL);
    tv->tv_sec = (long) ((now.ns100 - 116444736000000000LL) / 10000000LL);
    return (0);
}

//获取1970年至今UTC的微妙数
time_t GetUtcCaressing()
{
    timeval tv;
    gettimeofday(&tv);
    return ((time_t)tv.tv_sec*(time_t)1000000+tv.tv_usec);
}


void print(int src[],int length){
	for(int i=0;i<length;i++){
		cout<<src[i]<<" ";
	}
	cout<<endl;
}

void swap(int& a,int& b){
	int temp = a;
	a = b;
	b=temp;
}

//冒泡排序
void maopoSort(int src[],int length){
  cout<<"冒泡排序:";
  print(src,length);
  for(int i=0;i<length;i++){
      for(int j=0;j<length-1-i;j++){
        if(src[j]>src[j+1]){
        	int temp = src[j];
        	src[j] = src[j+1];
        	src[j+1]=temp;
        }
      }
  }
  print(src,length);
}
//简单选择排序
void xuanzheSort(int src[],int length){
	  cout<<"简单排序:";
	  print(src,length);
	  for(int i=0;i<length;i++){
		  int k = i;
	      for(int j=i+1;j<length;j++){
	        if(src[j]<src[k]){
	             k = j;
	        }
	      }
	      if(k!=i){
	    	  swap(src[k],src[i]);
	      }
	  }
	  print(src,length);
}

//插入排序
void charuSort(int src[],int length){
	  cout<<"插入排序排序:";
	  print(src,length);
   for(int i=0;i<length;i++){
	   int j=0;
	   int k=src[i];
	   for(j=i-1;j>=0&&src[j]>k;j--){
		   src[j+1]=src[j];
	   }
	   if(j+1!=i)
	      src[j+1] = k ;
   }
   print(src,length);
}


//快速排序
void kuaisuSort(int src[],int begin,int end){
   if(begin>=end)
		return;
   int mid =begin;
   int i=begin+1;
   int j=end;
   while(i<=j){
      while(src[i]<=src[mid]&&i<end) i++;
      while(src[j]>=src[mid]&&j>begin) j--;
      if(i<j){
        swap(src[i],src[j]);
      }else{
    	  break;
      }
      i++;
      j--;
   }
   swap(src[mid],src[j]);
   kuaisuSort(src,begin,j-1);
   kuaisuSort(src,j+1,end);
}
void kuaisuSort(int src[],int length){
	cout<<"快速排序:";
	print(src,length);
	kuaisuSort(src,0,length-1);
	print(src,length);
}


//堆排序
void maxHeap(int src[],int k,int length){//从0开始
   int m = src[k];
   int i = k;
   while(i<length){
	   int left=2*(i+1)-1;
	   int right=2*(i+1);
	   int lagest = 0;

	   if(right<length)
	       lagest = src[right]>src[left]?right:left;
	   else if(left<length)
		   lagest = left;
	   else
		   break;

	   if(src[lagest]>m){
              src[i]=src[lagest];
              i = lagest;
	   }else{
		   break;
	   }
   }
   if(i!=k)
	   src[i] = m;
}

void CreateDui(int src[],int length){
   for(int i=length/2-1;i>=0;i--){
	   maxHeap(src,i,length);
	   //print(src,length);
   }
}

void duiSort(int src[],int length){
	cout<<"堆排序:";
	print(src,length);
	CreateDui(src,length);
	for(int i=length-1;i>=1;i--){
	     swap(src[0],src[i]);
	     maxHeap(src,0,i);
	}
	print(src,length);
}

//希尔排序
void shellSortDela(int src[],int dela,int begin,int length){
    for(int i=begin;i<length;i+=dela){
    	int j=i-dela;
    	int m = src[i];
	   for(j=i-dela;src[j]>m&&j>=begin;){
           src[j+dela] = src[j];
           j=j-dela;
	   }
	   src[j+dela] = m;
    }
   // print(src,length);
}

void shellSort(int src[],int length){
	cout<<"shell排序:";
	print(src,length);
	for(int dela=length/2;dela>0;dela/=2){
		for(int i=0;i<dela;i++)
           shellSortDela(src,dela,i,length);
	}
	print(src,length);
}



//归并排序
void merge(int a[],int low,int mid,int high){
     int* b=new int[high-low+1];
     int i=low;
     int j=mid+1;
     int k=0;
     while(i<=mid&&j<=high){
    	 b[k++]=a[i]<=a[j]?a[i++]:a[j++];
     }
     while(i<=mid)
    	 b[k++]=a[i++];
     while(j<=high)
    	 b[k++]=a[j++];
    // memcpy(&a[low],b,(high-low+1)*sizeof(int));
     for(i=low;i<=high;i++){
          a[i] = b[i-low];
      }
     delete b;
}

void mergeSort(int a[],int begin,int end){
       if(begin>=end)
    	   return;
       int mid=(begin+end)/2;
       mergeSort(a,begin,mid);
       mergeSort(a,mid+1,end);
       merge(a,begin,mid,end);

}
void mergeSort(int a[],int length){
	cout<<"归并排序:";
	print(a,length);
	mergeSort(a,0,length-1);
	print(a,length);
}

//基数排序
void jisuSort(int a[],int length){
	cout<<"基数排序:";
	print(a,length);
   int* b = new int[10*length];
   int k[10]={0};
   bool flag=true;
   int m=1;
   while(flag){
	   flag = false;
	   memset(k,0,10*sizeof(int));
	   for(int i=0;i<length;i++){
		   int t = abs(a[i])/m;
		   if(t/10>0)
				 flag=true;
		   *(b+length*(t%10)+*(k+t%10)) = a[i];
		   *(k+t%10) = *(k+t%10)+1;
	   }
	   m *= 10;
	   int n=0;
	   for(int i=0;i<10;i++){
		   if(k[i]!=0){
               for(int j=0;j<k[i];j++){
            	   a[n++]=*(b+length*i+j);
               }
		   }
	   }
   }
   print(a,length);
   memset(k,0,10*sizeof(int));
   for(int i=0;i<length;i++){
      if(a[i]<0){
    	 *(b+k[0]) = a[i];
    	 k[0]++;
      }else{
     	 *(b+length+k[1]) = a[i];
     	 k[1]++;
      }
   }
   int n=0;
   for(int j=k[0]-1;j>=0;j--){
	   a[n++]=*(b+j);
   }
   for(int j=0;j<k[1];j++){
	   a[n++]=*(b+length+j);
   }
   delete b;
   print(a,length);
}
//计算排序时间
void computeTime(int a[],int length,void(*func)(int a[],int length)){
	int* b=new int[length];
	for(int i=0;i<length;i++){
		b[i]=a[i];
	}
	time_t t1= GetUtcCaressing();
	func(b,length);
	time_t t2= GetUtcCaressing();
	cout<<"算法消耗时间(100NS):"<<t2<<"-"<<t1<<"="<<t2-t1<<endl;
	delete b;
}

int main() {
	int a[]={3,2,-1,6,4,12,0,7,-4,29,-20};
	int length = sizeof(a)/sizeof(int);
	computeTime(a,length,maopoSort);
	computeTime(a,length,xuanzheSort);
	computeTime(a,length,charuSort);
	computeTime(a,length,kuaisuSort);
	computeTime(a,length,duiSort);
	computeTime(a,length,shellSort);
	computeTime(a,length,mergeSort);
	computeTime(a,length,jisuSort);

	return 0;
}

运行结果:

冒泡排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476843755--1476843755=0
简单排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476843755--1476843755=0
插入排序排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476843755--1476843755=0
快速排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476843755--1476843755=0
堆排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476843755--1476843755=0
shell排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476833754--1476843755=10001
归并排序:3 2 -1 6 4 12 0 7 -4 29 -20 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476833754--1476833754=0
基数排序:3 2 -1 6 4 12 0 7 -4 29 -20 
0 -1 2 3 4 -4 6 7 12 -20 29 
-20 -4 -1 0 2 3 4 6 7 12 29 
算法消耗时间(100NS):-1476833754--1476833754=0

抱歉!评论已关闭.