java 快速排序的思想及解释说明

5 篇文章 0 订阅

快速排序在应用上很广泛,大家有知道二分法,二分法在排好序的数组中查找数据是最快的

快速排序是在无序的数组中排序、查找相对是最快的

如今大数据时代,在数据量如此之大的情况下查找的速度是很重要的,那么认识快速排序的思想是很重要的,

快速排序的第一个思想:二分思想

就是把一个整体分成2份,每份单独处理,这样在查找数据时则非常快,

比如开始是 5 1 6 2 7 3 9 4

我们已5为基数划分

结果:4 1 3 2 5  7 6 9   

我们查找的时候就知道从哪边找啦,节约了大量的时间

快速排序的第二个思想:分而治之的思想

就是将一个整体分为若干个部分,再理由递归依次处理,假如有多个进程处理速度更快

这也是大数据处理的思想

代码如下:

</pre><pre code_snippet_id="1830803" snippet_file_name="blog_20160815_2_1033046" name="code" class="java">public class KuaiPai {
	public static void quicksort(int[] a, int left, int right){
	    
		int i,j,t,temp; 
	    
	    if(left>right) 
	       return; 
	                                
	    temp=a[left]; //temp中存的就是基准数 
	    i=left;  //左哨兵
	    
	    
	    j=right; //右哨兵
	    
	    while(i!=j) 
	    { 
	                   //顺序很重要,要先从右边开始找 
	               while(a[j]>=temp && i<j) 
	                   j--; 
	                   //再找右边的 
	               while(a[i]<=temp && i<j) 
	                  i++; 
	                   //交换两个数在数组中的位置 
	               if(i<j) 
	                   { 
	                     t=a[i]; 
	                     a[i]=a[j]; 
	                     a[j]=t; 
	               } 
	    } 
	    //最终将基准数归位 
	    a[left]=a[i]; 
	    a[i]=temp; 
	                             
	    quicksort(a,left,i-1);//继续处理左边的,这里是一个递归的过程 
	    quicksort(a,i+1,right);//继续处理右边的 ,这里是一个递归的过程 
        
       }
	
	public static void main(String[] args) {
		int x[]={6,1,2,7,9,3,4,5,10,8};
		
		quicksort(x, 0, x.length-1);
		for (int i = 0; i < x.length; i++) {
				System.out.println(x[i]);
		}

	}
}




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值