数据结构 排序算法
来源:互联网 发布:信息流广告数据分析 编辑:程序博客网 时间:2024/06/03 17:27
//============================================================================// 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
- c#数据结构------排序算法
- 数据结构-算法: 分配排序
- 数据结构排序算法总结
- 数据结构排序算法总结
- 数据结构之排序算法
- 数据结构-排序算法
- 数据结构中的排序算法
- 数据结构排序算法总结
- 数据结构之排序算法
- 数据结构算法----选择排序
- 数据结构排序算法总结
- 数据结构中的排序算法
- 【数据结构与算法】排序
- 数据结构-冒泡排序算法
- 数据结构-选择排序算法
- 数据结构-插入排序算法
- 数据结构之排序算法
- 数据结构排序算法归纳
- SQL SERVER读书笔记:TempDB
- [每日一题]11gOCP 1z0-052 :2013-09-11 MGR_ROLE role..........................................A66
- 嵌入式C开发基础题(12)
- HDU 1693
- Guava学习之Iterators
- 数据结构 排序算法
- UVA OJ 457 - Linear Cellular Automata
- JFrameHelloWorld
- ADO.NET之SqlDataAdapter对数据库增加、删除、修改篇
- SQL SERVER读书笔记:阻塞与死锁
- Javascript set and get methods Textarea cursor position
- 内存的自动刷新与自刷新
- VC枚举电脑上可用串口
- Accelerated C++学习笔记 Ch2