算法之-快速排序算法

本文介绍了一个经典的排序算法——快速排序,并提供了详细的实现代码。通过一个具体的示例展示了如何使用快速排序算法对整数数组进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

快速排序算法应用的比较广泛,是一个非常经典的排序算法,

public class QuickSort   {
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
         QuickSort quick=new QuickSort();
           Integer  []arrays={98,4,7,9,12,98,34,344,988,654,43,566,7,9,6,87,89,65,789,96};
         quick.sort(arrays);
       for (int i = 0; i < arrays.length; i++) {
		System.out.println(arrays[i]);
	}
	}
	public int partition(Integer[] arrays,int low,int hign){
	     int i = low,j=hign+1;
	     while(true){
	    	 
	    	 while(arrays[++i]<arrays[low]){
	    		 if(i==hign){
	    			 break;
	    		 }
	    	 }
	    	 while(arrays[--j]>arrays[low]){
	    		 if(j==low){
	    			 break;
	    		 }
	    	 }
	    	 if(i>=j){
	    		 break;
	    	 }
	    	 swap(arrays,i,j);
	    	 
	     }
	     swap(arrays,low,j);
		return j;
	}
	
   private void swap(Integer[] arrays, int i, int j) {
		int temp=arrays[i];
		arrays[i]=arrays[j];
		arrays[j]=temp;
		 
	}
   public  void sort(Integer [] arrays){
	  
	   sort(arrays,0,arrays.length-1);
	 
   }
private void sort(Integer []array,int i,int j){
	if(i>=j)
		return;
	int index=partition(array, i, j);
	sort(array, i, index-1);
	sort(array, index+1, j);
}
	

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

house.zhang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值