Java 快排 看着一片就够了

楼主在复习快速排序的时候发现了很多问题,其中也参照了大神的代码,进行了代码的详细说明

大神代码地址,有很好的图例说明 请点击

  • 我的代码实现
package sort;

public class QuickSort {

    /**
     * 快速排序
     * <p>
     * 从数列中挑出一个元素,称为“基准”
     * 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。
     * 在这个分割之后,该基准是它的最后位置。这个称为分割(partition)操作。
     * 递归地把小于基准值元素的子数列和大于基准值元素的子数列排序。
     *
     * @param arr  数组
     * @param low  开始
     * @param high 结束
     */


    public static void quickSortRightMax(int[] arr, int low, int high) {
        if (low > high) {
            return;
        }
        int i = low;
        int j = high;
        int key = arr[i];
        int temp = 0;
        while (i < j) {
            while ((arr[j] >= key) && (j > i)) {
            /*从后往前比较
                如果没有比关键key小的,比较下一个,直到找到比关键key小的
            */
                j--;
            }


            while ((arr[i] <= key) && (j > i)) {
            /*从往前往后比较
                如果没有比关键key大的,比较下一个,直到找到比关键key大的
            */
                i++;
            }

            if (i < j) {
                //找到了比关键key大的值,和比Key小的值,调换位置
                temp = arr[j];
                arr[j] = arr[i];
                arr[i] = temp;
            }

        }
        // 此时哨兵i和哨兵j相遇了,哨兵i和哨兵j都走到key面前。
        // 说明此时“探测”结束。我们将基准数arr[low]也就是Key所代表的值和arr[i]进行交换。
        arr[low] = arr[i];
        arr[i] = key;

        // 交换完了之后,就是以基准Key分成了2部分,左边是小于key的,右边是大于key的
        // 比如: int arr2[] = new int[]{6,1,2,7,9,3,4,5,10,8};
        // 现在变成了 3,1,2,5,4,6,9,7,10,8左边是3,1,2,5,4 右边是9,7,10,8
        // 接下来还需要分别处理这两个序列。
        // 左边的序列是“3 1 2 5 4”。
        // 请将这个序列以3为基准数进行调整,使得3左边的数都小于等于3,3右边的数都大于等于3。

        System.out.println(i == j);
        System.out.println("===============");
        //递归调用左半数组,因为此时i=j,所以用i j都行
        quickSortRightMax(arr, low, j - 1);
        //递归调用左半数组
        quickSortRightMax(arr, j + 1, high);
    }


    public static void main(String[] args) {
        int arr2[] = new int[]{6, 1, 2, 7, 9, 3, 4, 5, 10, 8, 11};
        quickSortRightMax(arr2, 0, arr2.length - 1);
        System.out.println("------------");
        for (int i = 0; i < arr2.length; i++) {
            System.out.println(arr2[i]);
        }
    }


}

  • 注意事项

这里比较的时候不管是《= 还是》= 都要带=号,因为我们要找的是比它小的,或者大的
((arr[i] <= key) && (j > i))
还有明明外边已经有i< j了为什么里面还要有?这是必须的,因为里面在做++ 和——运算

  • 时间和空间复杂度

排序算法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值