JAVA快速排序(亲测可用)

最近学习算法,看到网上有很多快速排序的帖子,但是大多都是粘贴复制,能正确运行的寥寥无几,所以自己在运行成功后在这里记录一下,主要是怕自己忘记,同时也希望能跟有相同兴趣的人一起学习,本人菜鸡新手,如果有哪里有问题,你咬我呀。。哈哈 开个玩笑,发现错误希望指出,大家一起学习,进步,成为更靠谱的程序员。

快速排序:
概念和排序思维这里就不细说了,因为这种理论的学说网上一大把。这里直接上代码了。

public static void main(String[] args) throws Exception {
        long startTime = System.currentTimeMillis();
        int[] ints = {9, 3, 7, 1, 2, 4, 5, 8, 6};

        //执行排序算法
        qsort(ints, 0, ints.length - 1);
        long endTime = System.currentTimeMillis();
        Arrays.stream(ints).forEach(d -> System.out.print(d));
        System.out.println();
        System.out.println((endTime - startTime) + " ms");
    }

    /**
     * 分割功能,将数组以基准值为基础进行分割
     * @param arr
     * @param low
     * @param high
     * @return
     */
    public static int partition(int[] arr, int low, int high) {
        int pivot = arr[high]; //基准值选择,这里选择的是数组最后一个值
        int j; //这个参数是为了遍历除基准值以外的全部数组。
        int i = low - 1; //这个参数是确定交换位置,为了对符合条件的数值进行交换
        for (j = low; j <= high - 1; j++) { //因为最后一个值被选择为基准值所以不用遍历。
            if (arr[j] <= pivot) { //从起始位置进行遍历,与基准值进行比较,如果数值小于基准值,就与i++(因为i被生命为 -1) 进行换位。
                i++;
                int tmp = arr[j];
                arr[j] = arr[i];
                arr[i] = tmp;
            }
        }
        //遍历到最后 i+1的位置就是基准值应该在的位置,所以进行交换。
        int tmp = arr[high];
        arr[high] = arr[i + 1];
        arr[i + 1] = tmp;
        return i + 1;//最后返回基准值的位置,以方便分割数据,进行递归调用。
    }

    /**
     * 排序
     * @param arr
     * @param low
     * @param high
     * @throws Exception
     */
    public static void qsort(int[] arr, int low, int high) throws Exception {
        if (arr == null) {
            throw new Exception("数组不能为null");
        }
        if (low >= high){//起始位置和结束位置相同,说明数组就只有一个值,或者没有值,直接return
            return;
        }
        int p = partition(arr, low, high);//这里返回分割的位置索引
        //对数组进行递归
        qsort(arr, low, p - 1);
        qsort(arr, p + 1, high);
    }
}

排序后的输出
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值