算法通关村第十关|青铜|快速排序

快速排序的核心框架是"二叉树的前序遍历+对撞型双指针"。

快速排序的实现1:

java 复制代码
public void quickSort(int[] arr, int left, int right) {
	if (left < right) {
        // pivot将遍历的范围限制在了pivot之前
        int pivot = arr[right];
        int i = left - 1;
        for (int j = left; j < right; j++) {
            if (arr[j] < pivot) {
                i++;
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
        // 哨兵移动到pivotIndex上
        int pivotIndex = i + 1;
        int temp = arr[pivotIndex];
        arr[pivotIndex] = arr[right];
        arr[right] = temp;

        quickSort(arr, left, pivotIndex - 1);
        quickSort(arr, pivotIndex + 1, right);
    }
}

快速排序的实现2:

java 复制代码
public void quickSort(int[] array, int start, int end) {
	if (start >= end) {
        return;
    }
    int left = start, right = end;
    int pivot = array[(start + end) / 2];

    while (left <= right) {
        while (left <= right && array[left] < pivot) {
            left++;
        }
        while (left <= right && array[right] > pivot) {
            right--;
        }
        if (left <= right) {
            int temp = array[left];
            array[left] = array[right];
            array[right] = temp;
            left++;
            right--;
        }
    }
    quickSort(array, start, right);
    quickSort(array, left, end);
}

如果对您有帮助,请点赞关注支持我,谢谢!❤

如有错误或者不足之处,敬请指正!❤

个人主页:星不易

算法通关村专栏:不易|算法通关村

相关推荐
liliangcsdn1 分钟前
mac mlx大模型框架的安装和使用
java·前端·人工智能·python·macos
今禾18 分钟前
一行代码引发的血案:new Array(5) 到底发生了什么?
前端·javascript·算法
Shimiy25 分钟前
第六章 面向对象编程------进阶
java
橙几28 分钟前
击败了90%的解法?Two Sum 从 O(n²) 到 O(n) 的优化之路
算法
大葱白菜29 分钟前
Java Set 集合详解:从基础语法到实战应用,彻底掌握去重与唯一性集合
java·后端
大葱白菜31 分钟前
Java Map 集合详解:从基础语法到实战应用,彻底掌握键值对数据结构
java·后端
添乱31 分钟前
「Java案例」判断是否是闰年的方法
java
FG.35 分钟前
Day22
java·面试
菜鸟的迷茫37 分钟前
Redis 缓存雪崩、穿透、击穿面试题深度解析与 Spring Boot 实战代码示例
java
叶子爱分享42 分钟前
经典排序算法之归并排序(Merge Sort)
算法·排序算法