java快速排序代码

java快速排序代码

例子:{3,4,2,7,2,6}

想要:将pivot左边变为比其小的数字,右边变为比其大的数字,在递归pivot的左边右边。
(1)默认选取第一位数字做为标杆pivot=3;
(2)int l=0(数组下标) 指向首位数字3;
(3)int r=5(数组下标)指向末尾数字6;
(4)通过while先从右向左通过对r–找到比pivot小的数字r=4;
(5)在通过while先从左向右通过对l++找到比pivotda的数字l=1;
(6)交换{3,2,2,7,4,6}
在循环(4)(5),直到l=r=2 {3,2,2,7,4,6}
(7)再将首位数字与l指向的值进行交换{2,2,3,7,4,6}
(8)在对l=r左边右边的值进行递归

package com.ExtraHomework1;

import java.util.Arrays;

/**
 * @Author zp
 * @Date 2022/7/20 8:12 PM
 * @Description: TODO
 */

public class SortDemo {
    public static void main(String[] args) {
        int[] a = {12,2,4,64,6,87,9};
        quickSort(a,0,a.length-1);
        System.out.println(Arrays.toString(a));
//        for (int i = 0;i<a.length-1;i++){
//            for (int j = 0;j<a.length-1-i;j++){
//                if(a[j]>a[j+1]){
//                    int temp;
//                    temp = a[j];
//                    a[j] = a[j+1];
//                    a[j+1] = temp;
//                }
//            }
//        }
//        for (int i = 0;i<a.length;i++){
//            System.out.println(a[i]);
//        }
    }

    public static void quickSort(int[] a,int start,int end){
        //如果区间不合理直接返回
        if(start>=end){
            return;
        }
        int pivot = a[start];//取首位数字做为标杆
        int l = start;//初始化l指向首位数字
        int r = end;//初始化r指向末尾数字
        while(l != r){
            //根据对r的改变,从右向左找出首个比pivot小的数字
            while(l < r && a[r]>=pivot){
                r--;
            }
            //根据对l的改变,从左向右找出首个比pivot大的数字
            while(l < r && a[l]<=pivot){
                l++;
            }
            //交换l和r对应的值
            if (l < r){
                int temp;
                temp = a[r];
                a[r] = a[l];
                a[l] = temp;
            }
        }

        /**
         * 当l=r是;a[l]肯定小于pivot所以交换。 因为初始l指向a[start]=pivot,
         * 程序要从右向左先找r指向比pivot小的值(准备交换),在从左往右找l指向比pivot大的值交换。
         * 如果找到了则交换,此时l指向的值变为比pivot小。如果没有找到,直到l=r程序结束,l指向的值依然比pivot小。
         * 将此时l=r指向的值与start指向的值交换(pivot),则实现了l=r指向的位置左边的值比pivot大,右边的值比pivot小
         */

        a[start] = a[l];
        a[l] = pivot;

        //在递归对左右两边的程序进行排序
        quickSort(a,start,l-1);
        quickSort(a,l+1,end);
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值