快速排序法 java代码 基本算法

基本思想:每次排序的时候设置一个基准点,将小于基准的数全部放到基准点
的左边,将大于基准点的数全部放到基准点的右边

import java.util.Scanner;

public class 快速排序 {

	public static void main(String[] args) {
		// TODO 自动生成的方法存根
		                    
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();
		
		int [] a=new int [n];
		for(int i=0;i<n;i++) {
			a[i]=sc.nextInt();
		}
		//调用
		quicklySort(a,0,n-1);
		//输出
		for(int j=0;j<n;j++) {
			System.out.print(a[j]);
		}
	}
     
	private static void quicklySort(int [] a,int left,int right) {
		
		//判断左边是否大于右边
		if(left>right) {
			return;
		}

		int	temp=a[left];   //基准数
		int i=left;
		int j=right;
		int t;        //交换用的杯子

		while(i!=j) {

			 //如果右边的数大于基准数,则 j--,若不满足条件则交换
			while(a[j]>=temp && i<j) {
				j--;
			}
            //如果左边的数小于基准数,则i++,做不满足条件则交换
			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;

		quicklySort(a, left,i-1);   //递归,继续处理左边
		quicklySort(a,i+1,right);     //递归,继续处理右边

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值