排序数组(快速排序算法)

目录

一:题目链接

二:题目思路

区域划分:

递归执行:

三:代码实现


一:题目链接

二:题目思路

这题主要由两大思路一起解决,一是 "区域划分" ,二是 "递归执行",现在分别解释这两个思路。

区域划分:

假设现有一个数组,我们在数组随机取一个基准值 key ,然后准备将数组从左到右划分为 < key ,== key, >key 三个区域,如图:

所以,为了完成上图的情况,我们定义left 下标在 -1,right 下标在 n(后面会解释)定义一个变量 i 用来遍历这个数组,变量 i 在遍历的过程中会将数组划分为四个区域:

其中区域1为0,left ,区域2为 left + 1,i -1 , 区域3为 i , right - 1 , 区域4为 right , n - 1区域 1 和区域 2 代表 < key(将 == key 的情况包含了) ,区域 3 代表未遍历的,区域4代表 > key。接下来 i 在遍历时会遇到的三种情况:

当 nums i < key,此时交换 left + 1位置 和 i 位置下标的元素,后续 i++ , left++。

当 nums i == key,直接 i++。

当 nums i > key,此时交换 left + 1位置 和 i 位置下标的元素,后续 right--。(此时 i 位置得到的元素是未知的,所以不能 i++)

现在就解释,所以为什么 left 下标在 -1,right 下标在 n,因为代码完成了交换元素前会进行 left + 1 或 left + 1,防止下标越界。

这一思路总结代码就是:

java 复制代码
        while(i < right) {
            if(nums[i] < key) {
                swap(nums,++left,i++);
            }else if(nums[i] == key) {
                i++;
            }else {
                swap(nums,--right,i);
            }
        }

递归执行:

上述的区域划分只是完成了一次数组按照一个基准值来进行排序得到的三个区域,对划分后区域的子数组重复上述过程,当执行区域划分次数足够多时,就完成了快速排序。

三:代码实现

java 复制代码
    public int[] sortArray(int[] nums) {
        qsort(nums,0,nums.length - 1);
        return nums;
    }

    public static void qsort(int[] nums,int l,int r) {

        //判断
        if(l >= r) {
            return;
        }

        //取基准值
        int key = nums[new Random().nextInt(r - l + 1) + l];

        //主逻辑
        int i = l;
        int left = l - 1;
        int right = r + 1;
        while(i < right) {
            if(nums[i] < key) {
                swap(nums,++left,i++);
            }else if(nums[i] == key) {
                i++;
            }else {
                swap(nums,--right,i);
            }
        }

        //继续分块操作
        qsort(nums,l,left);
        qsort(nums,right,r);
    }

    public static void swap(int[] nums,int a,int b) {
        int c = nums[a];
        nums[a] = nums[b];
        nums[b] = c;
    }
相关推荐
NE_STOP12 小时前
Vide Coding--AI编程工具的选择
java
通信小呆呆12 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
码云数智-园园12 小时前
C++20 Modules 模块详解
java·开发语言·spring
程序员黑豆12 小时前
JDK 下载安装与配置详细教程
java·前端·ai编程
benben04413 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
小宇宙Zz13 小时前
Maven依赖冲突
java·服务器·maven
swordbob13 小时前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
咖啡八杯13 小时前
GoF设计模式——享元模式
java·spring·设计模式·享元模式
小小工匠13 小时前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化