【LeetCode Hot100 | 每日刷题】排序数组

912. 排序数组 - 力扣(LeetCode)

题目:

给你一个整数数组 nums,请你将该数组升序排列。

你必须在 不使用任何内置函数 的情况下解决问题,时间复杂度为 O(nlog(n)),并且空间复杂度尽可能小。

示例 1:

复制代码
输入:nums = [5,2,3,1]
输出:[1,2,3,5]

示例 2:

复制代码
输入:nums = [5,1,1,2,0,0]
输出:[0,0,1,1,2,5]

方法:快速排序

快速排序核心就是分而治之,在当前排序区间[L,R]选定一个元素X作为中间值,X可以是nums[L+1],nums[R-1],nums[(L+R)/2],下面我们选择nums[(L+R)/2]作为中间值,元素依次与X比较,小于X的元素在X左边,大于X的元素在X右边,并且再次递归排序左边的区间以及X右边的区间,直至整个数组完成排序。

Java实现代码:

java 复制代码
class Solution {
    public int[] sortArray(int[] nums) {
        int n=nums.length;
        quicksort(nums,0,n-1);
        return nums;
    }
    public void quicksort(int []nums,int l,int r){
        if(l==r)return;
        int x=nums[(l+r)/2];
        int i=l-1;
        int j=r+1;
        while(i<j){
            do i++;while(nums[i]<x);
            do j--;while(nums[j]>x);
            if(i<j){
                int tem=nums[i];
                nums[i]=nums[j];
                nums[j]=tem;
            }
        }
        quicksort(nums,l,j);
        quicksort(nums,j+1,r);
    }
}

平均时间复杂度:O(nlogn),最差时间复杂度为O(n^2),即每次取到的X都是当前区间的最大值或最小值,相当于冒泡排序了。

相关推荐
阿Y加油吧5 分钟前
力扣打卡day07——最大子数组和、合并区间
算法
想吃火锅100510 分钟前
【leetcode】105. 从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
圣保罗的大教堂11 分钟前
leetcode 3567. 子矩阵的最小绝对差 中等
leetcode
2401_8318249616 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
靠沿18 分钟前
【优选算法】专题十八——BFS解决拓扑排序问题
算法·宽度优先
cui_ruicheng21 分钟前
C++数据结构进阶:哈希表实现
数据结构·c++·算法·哈希算法·散列表
光电笑映24 分钟前
高阶数据结构之红黑树详解
数据结构
li星野32 分钟前
[特殊字符] 模拟试卷一:C++核心与系统基础(90分钟)答案版
开发语言·c++·算法
二进制星轨1 小时前
leecode-283-移动零-算法题解
算法
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #215:数组中的第K个最大元素(快速选择、堆排序、计数排序等多种实现方案详解)
算法·leetcode·堆排序·快速选择·topk·数组中的第k个最大元素