快速排序java版

这里是快速排序算法
public class QuickSort {
	public static void main(String[] args) {
		int []a = {1,5,2,6,8,9,10,3,5,13,18,0,7,43,26,47};
		sort(a,0,a.length-1);
		print(a);
	}
	public static void sort(int arr[],int low,int high){
	  int l=low;
	 int h=high;
	 int povit=arr[low];
	 
	while(l<h){
	  
		while(l<h&&arr[h]>=povit)h--;
	   
		if(l<h){
	      int temp=arr[h];
	      arr[h]=arr[l];
	      arr[l]=temp;
          l++;
	      }
	 
	   while(l<h&&arr[l]<=povit)l++;
	 
	   if(l<h){
		   int temp=arr[h];
		   arr[h]=arr[l];
		   arr[l]=temp;
		   h--;
	          }
      }
      print(arr);
      System.out.println("l= "+(l+1)+" h="+(h+1)+" povit="+povit+"\n");
      if(l>low)sort(arr,low,h-1);
      if(h<high)sort(arr,l+1,high);
      }
	private static void print(int[] arr) {
		// TODO 自动生成的方法存根
		for(int i=0;i<arr.length;i++){
			System.out.print(arr[i]+" ");
			if((i+1) % 8 == 0 )System.out.print("\n");
		}
		System.out.print("\n");
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YuYunTan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值