快速排序算法

快排版本1:最差O(n^2) 划分值很偏

总拿最后一个数做划分,划分好最后一个数和大于区的第一个数做交换,然后在小于等于5区域和大于5区域继续往复循环操作,都取各自的最后一个数作为基准数。

快排版本2:最差O(n^2) 划分值很偏

每次排序都能搞定一堆等于5的区域。只要最后一个数和大于区的第一个数做交换

然后左右侧以最后一个数作为基准数,继续做递归。

快排 【最好情况 几乎在中点】O(n*logn)

L到R随机选个数和最后位置做交换,拿最后位置做划分。

举例

L和R的索引分别是10和15

partition后就返回12和13,表示的是划分值区域的左边界和右边界

复制代码
public int[] sortArray(int[] nums) {
        if(nums == null || nums.length < 2){
            return nums;
        }
        quickSort(nums,0,nums.length - 1);
        return nums;
    }

    //交换位置
    public void swap(int[] nums,int L,int R){
        int temp = 0;
        temp = nums[L];
        nums[L] = nums[R];
        nums[R] = temp;
    }

    // 快排
    public void quickSort(int[] arr,int L,int R){
        if(L < R){
            // *精华!随机数和最后一个数做交换  随机数:0 <= r < 1
            swap(arr,L + (int)(Math.random() * (R - L + 1)),R);
            // 拿L和R范围上 以及我选出来的最后一个位置上 做partition
            // 返回数组长度一定是2,中间排好序的左边界和右边界
            int[] p = partition(arr,L,R);
            // p[0]是等于区域的左边界,p[0]-1就是小于区域右边界
            quickSort(arr,L,p[0]-1);
            // p[1]是等于区域的右边界,p[1]+1就是大于区域左边界
            quickSort(arr,p[1]+1,R);
        }
    }

    public int[] partition(int[] arr,int L,int R){
        // <区右边界
        int less = L - 1; 
        // <区左边界
        int more = R;
        // arr[L]表示当前数的位置 还没碰上右边界的第一个数 排序
        while(L < more){
            if(arr[L] < arr[R]){
                swap(arr,++less,L++);
            }else if(arr[L] > arr[R]){
                // >区左扩
                swap(arr,--more,L);
            }else{
                L++;
            }
        }
        // 都做完后,最后一个数和大于区第一个做交换
        swap(arr,more,R);
        // 返回中间排好序的左边界和右边界
        return new int[] {less + 1,more};
    }
相关推荐
JieE21210 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言