排序算法-快速排序

Leetcode链接:. - 力扣(LeetCode)

快速排序:随机选一个基准数据,通过一趟排序将待排序的记录分割成独立的三部分,第一部分记录的数组小于基准数据,第二部分记录的数组等于基准数据,第三部分记录的数组大于基准数据,过程执行完,基准数据已经在数组中的正确位置,递归地进行这个过程,直到整个序列有序为止。

1.设置两个区域,分别为<区(小于基准数据num)和>区(大于基准数据num)

2.随机再数组中选一个基准数据num,遍历数组arr[i];

2.1 如果arr[i]<num,arr[i]和<区的下一个数据交换,<区右移一位,i++;

2.2 如果arr[i]=num,i++;

2.3 如果arr[i]>num,arr[i]和>区的前一个数据交换,>区左移一位,i不变。

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

    public void quickSort(int[] arr ,int l,int r){
        if(l<r){
            //随机选取一个基准数跟r交换(基准数最好是随机选取的,减小最坏情况的可能)
            swap(arr,l+(int)(Math.random() * (r-l+1)),r);
            //p存放等于基准数的左右边界
            int[] p=partition(arr,l,r);
            quickSort(arr,l,p[0]-1); //<区
            quickSort(arr,p[1]+1,r);//>区
        }
    }

    public int[] partition(int[] arr,int l,int r){
        int small = l-1;
        int big =r;

        while(l<big){
            //arr[l]<基准数,arr[l]和arr[small]的下一个数交换,small右移一位,l加一
            if(arr[l]<arr[r]){
                swap(arr,++small,l++);
            //arr[l]>基准数,arr[l]和arr[big]的前一个数交换,big左移一位,l不变
            } else if(arr[l]> arr[r]){
                swap(arr, --big,l);
            //arr[l]=基准数,l加一
            }else {
                l++;
            }
        }
        //交换arr[big]和基准数
        swap(arr,big,r);
        return new int[]{small+1,big};
    }


    public void swap(int[] arr, int a,int b){
       int temp=arr[a];
		arr[a]=arr[b];
		arr[b]=temp;
    }
    
}
相关推荐
只想码代码几秒前
什么是程序计数器?
java·jvm
JAVA学习通3 分钟前
OJ竞赛平台----C端题目列表
java·开发语言·jvm·vue.js·elasticsearch
让我们一起加油好吗4 分钟前
【基础算法】多源 BFS
c++·算法·bfs·宽度优先·多源bfs
B站计算机毕业设计之家10 分钟前
深度学习实战:python动物识别分类检测系统 计算机视觉 Django框架 CNN算法 深度学习 卷积神经网络 TensorFlow 毕业设计(建议收藏)✅
python·深度学习·算法·计算机视觉·分类·毕业设计·动物识别
And_Ii23 分钟前
LeetCode 3350. 检测相邻递增子数组 II
数据结构·算法·leetcode
想唱rap27 分钟前
C++ string类的使用
开发语言·c++·笔记·算法·新浪微博
JAVA学习通27 分钟前
Replication(下):事务,一致性与共识
大数据·分布式·算法
胖咕噜的稞达鸭27 分钟前
C++中的父继子承(2)多继承菱形继承问题,多继承指针偏移,继承组合分析+高质量习题扫尾继承多态
c语言·开发语言·数据结构·c++·算法·链表·c#
蓝色汪洋30 分钟前
Completed String easy
算法
得物技术31 分钟前
从 JSON 字符串到 Java 对象:Fastjson 1.2.83 全程解析|得物技术
java·后端·json