zoukankan      html  css  js  c++  java
  • 快速排序

    #include<iostream>
    using namespace std;
    
    void quick_sort(int a[],int left,int right){
    
    	//终止条件——————————————————————————————————1
    	if(left>=right)
    		return ;
    	
    
    	//关键代码——————————————————————————————————2
    	
    	int pivot=a[left];	//pivot作为枢纽,比pivot大的数在左侧,小于pivot的数置于右侧。
    	int i=left,j=right;
    	
    	while (i<j)	{//关键性循环,一个萝卜一个坑。右→左(--j);左→右(++i)。。。
    		while(i<j && a[j]>=pivot) --j;
    		if (i<j){	
    			a[i]=a[j];//a[i]=a[j]后,a[j]的值就可以被后续的a[i]覆盖了
    			++i;//a[i]处目前为小于pivot的原a[j]的值,i需要右移一位
    		}
    
    		while(i<j && a[i]<=pivot) ++i;
    		if(i<j){
    			a[j]=a[i];//a[j]=a[i]后,a[i]的值就可以被后续的a[j]覆盖了
    			++j;//a[j]处目前为大于pivot的原a[i]的值,j需要左移一位
    		}
    
    	}
    	a[i]=pivot;//while循环结束时i==j,找到pivot的坑。
    	
    	//分治————————————————————————————————————3
    	quick_sort(a,left,i-1);
    	quick_sort(a,i+1,right);
    }
    
    int main(){
    	int array[]={6, 3, 5, 7, 2, 4, 1, 8, 10, 9};
        quick_sort(array,0,sizeof(array)/sizeof(array[0]) -1);
        for(int i=0;i<sizeof array/sizeof array[0];i++)
            cout<<array[i]<<" ";
        cout<<endl;
    	return 0;
    }

  • 相关阅读:
    数据库对象命名参考
    写有效率的SQL查询(I)
    一個常用的phpclass類
    写有效率的SQL查询(IV)
    深入浅出理解索引结构
    Java初学者:Jsp开发环境配置全过程
    总结性知识:做网站的一些定律
    如何在JBuilder2007中配置MyEclipse
    幾個有用的ASP Function
    [SQL] 系统存储过程
  • 原文地址:https://www.cnblogs.com/sjw1357/p/3864007.html
Copyright © 2011-2022 走看看