【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都是当前区间的最大值或最小值,相当于冒泡排序了。

相关推荐
PixelMind1 小时前
【LUT技术专题】图像自适应3DLUT
图像处理·深度学习·算法·3dlut
木子.李3472 小时前
数据结构-算法学习C++(入门)
数据库·c++·学习·算法
GIS小天2 小时前
AI预测3D新模型百十个定位预测+胆码预测+去和尾2025年5月31日第94弹
人工智能·算法·机器学习·彩票
武子康3 小时前
大数据-274 Spark MLib - 基础介绍 机器学习算法 剪枝 后剪枝 ID3 C4.5 CART
大数据·人工智能·算法·机器学习·语言模型·spark-ml·剪枝
Thanks_ks3 小时前
深入链表剖析:从原理到 C 语言实现,涵盖单向、双向及循环链表全解析
数据结构·链表·c 语言·双向链表·单向链表·循环链表·算法与编程
moz与京3 小时前
【数据结构】字符串操作整理(C++)
开发语言·数据结构·c++
爱coding的橙子4 小时前
每日算法刷题Day19 5.31:leetcode二分答案3道题,用时1h
算法·leetcode·职场和发展
初遇你时动了情5 小时前
dart常用语法详解/数组list/map数据/class类详解
数据结构·flutter·list
地平线开发者5 小时前
征程 6EM 常见 QConfig 配置解读与示例
算法·自动驾驶
GEEK零零七6 小时前
Leetcode 1908. Nim 游戏 II
算法·leetcode·博弈论