zoukankan      html  css  js  c++  java
  • 冒泡,插入,希尔,快排的比较

    #include <windows.h>
    #include <stdlib.h> 
    #include <stdio.h> 
    #include <time.h>
    #include <ctime>
    #include <algorithm> 
    #define ARRLEN 10000
    using namespace std;
    
    int arr[ARRLEN],arr1[ARRLEN],arr2[ARRLEN],arr3[ARRLEN];
    void BubbleSort(int arr[], int n)
    {
    	for(int i=0;i<n-1; ++i)
    	{
    		for(int j=0;j<n-1-i;++j)
    		{
    			if(arr[j]>arr[j+1])
    			{
    				swap(arr[j],arr[j+1]);
    			}
    		}
    	}
    
    }
    void InsertSort(int arr1[],int n){
    	int i,j;
    	for (i=1;i<n;i++)
    	{
    		for(j=i-1;j>=0&&arr1[j]>arr1[j+1];j--)
    
    			swap(arr1[j],arr1[j+1]);
    	}
    }
    void ShellSort(int arr2[],int n)
    {
    	int i,j,gap;
    	for (gap=n/2;gap>0;gap/=2)
    	{
    
    		for (i=gap;i<n;i++)
    		{
    
    			for(j=i-gap;j>=0&&arr2[j]>arr2[j+gap];j-=gap)
    
    				swap(arr2[j],arr2[j+gap]);
    		}
    	}
    }
    int Patition(int arr3[], int low, int high)
    {
    
    	int pivotkey=arr3[low];
    	int temp = arr3[low];
    
    	while(low<high)
    	{
    
    		while(low <high && arr3[high]>=pivotkey)
    		{
    			--high;;
    		}
    		arr3[low]=arr3[high];
    		while(low<high && arr3[low]<=pivotkey)
    		{
    			++low;;
    		}
    		arr3[high]=arr3[low];
    	}
    	arr3[low] = temp;
    	return low;
    
    }
    void QuickSort(int arr3[], int low, int high)
    {
    	if(low<high)
    	{
    		int pivotloc=Patition(arr3,low, high);
    		QuickSort(arr3, low, pivotloc-1);
    		QuickSort(arr3, pivotloc+1, high);
    	}
    }
    void InitArr(){
    	for (int i=0,j;i<ARRLEN;i++)
    	{
    		j=rand()%10000;
    		arr[i]=j;arr1[i]=j;arr2[i]=j;arr3[i]=j;
    	}
    }
    void Display(int arr[],int n){
    	int i=0;
    	while(n--){
    		printf("%d ",arr[i]);
    		i++;
    	}
    }
    int main(void){
    	DWORD start, stop;
    	printf("BubbleSort:\n");
    	InitArr();
    	start = GetTickCount();
    	BubbleSort(arr,ARRLEN);
    	stop = GetTickCount();
    	printf("time: %I64d ms\n", stop - start);
    	//Display(arr,ARRLEN);
    	printf("InsertSort:\n");
    	start = GetTickCount();
    	InsertSort(arr1,ARRLEN);
    	stop = GetTickCount();
    	printf("time: %I64d ms\n", stop - start);
    	//Display(arr,ARRLEN);
    	printf("ShellSort:\n");
    	start = GetTickCount();
    	ShellSort(arr2,ARRLEN);
    	stop = GetTickCount();
    	printf("time: %I64d ms\n", stop - start);
    	//Display(arr,ARRLEN);
    	printf("QuickSort:\n");
    	start = GetTickCount();
    	QuickSort(arr3,0,ARRLEN-1);
    	stop = GetTickCount();
    	printf("time: %I64d ms\n", stop - start);
    	//Display(arr,ARRLEN);
    	getchar();
    	return 0;
    }

     

  • 相关阅读:
    存储过程和触发器
    RuPengWang项目
    短信验证
    Lucene.Net 站内搜索
    Quartz 定时任务(含Redis)
    网上支付(支付宝/银联)
    iOS 图片选择的路径处理(转)
    iOS 使用cocoaPods总结 ----摩天居士博客
    iOS 开发之本地化 国际化
    iOS 8 Xcode6 设置Launch Image 启动图片<转>
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3061720.html
Copyright © 2011-2022 走看看