java实现快速排序

图解

快速排序是一种常见的排序算法,它通过选取一个基准元素,将待排序的数组划分为两个子数组,一个子数组中的元素都小于基准元素,另一个子数组中的元素都大于基准元素。然后递归地对子数组进行排序,直到子数组的长度为1或0。

快速排序的步骤如下:

  1. 选择一个基准元素,通常选择数组的第一个元素。
  2. 将数组划分为两个子数组,左边的子数组中的元素都小于基准元素,右边的子数组中的元素都大于基准元素。可以使用双指针法实现。
  3. 对左边的子数组递归地应用上述步骤,对右边的子数组递归地应用上述步骤,直到子数组的长度为1或0。

快速排序的时间复杂度为O(nlogn),空间复杂度为O(logn),其中n为待排序数组的长度。

快速排序是一种高效的排序算法,以下是Java代码实现:

复制代码
public class QuickSort {
    
    public static void quickSort(int[] arr, int left, int right) {
        if (left < right) {
            int pivotIndex = partition(arr, left, right); // 获取基准值的位置
            quickSort(arr, left, pivotIndex - 1);  // 递归排序左子数组
            quickSort(arr, pivotIndex + 1, right); // 递归排序右子数组
        }
    }
    
    public static int partition(int[] arr, int left, int right) {
        int pivot = arr[left];   // 将左边第一个元素选为基准值
        while (left < right) {
            // 从右边开始找到第一个小于基准值的元素
            while (left < right && arr[right] >= pivot) {
                right--;
            }
            // 将小于基准值的元素放到左边
            arr[left] = arr[right];
            // 从左边开始找到第一个大于基准值的元素
            while (left < right && arr[left] <= pivot) {
                left++;
            }
            // 将大于基准值的元素放到右边
            arr[right] = arr[left];
        }
        arr[left] = pivot;  // 将基准值放到中间
        return left;    // 返回基准值的位置
    }
    
    public static void main(String[] args) {
        int[] arr = {6, 1, 3, 9, 2, 7, 4, 8, 5};
        quickSort(arr, 0, arr.length - 1);
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}

快速排序的时间复杂度为O(nlogn)。

相关推荐
溟洵几秒前
【算法C++】链表(题目列表:两数相加、两两交换链表中的节点、重排链表、合并 K 个升序链表、K 个一组翻转链表7)
数据结构·c++·算法·链表
_OP_CHEN几秒前
【C++数据结构进阶】玩转并查集:从原理到实战,C++ 实现与高频面试题全解析
数据结构·c++·算法
gugugu.1 分钟前
算法:hot100---128. 最长连续序列
算法
天呐草莓7 分钟前
支持向量机(SVM)
人工智能·python·算法·机器学习·支持向量机·数据挖掘·数据分析
zore_c19 分钟前
【数据结构】队列——超详解!!!(包含队列的实现)
c语言·网络·数据结构·c++·笔记·算法·链表
小杰帅气20 分钟前
智能指针喵喵喵
开发语言·c++·算法
智驱力人工智能29 分钟前
守护生命的水上之眼 无人机人员落水检测系统的技术攻坚与应用实践 无人机溺水识别 山区水库无人机落水检测系统 水域安全无人机部署指南
大数据·人工智能·算法·安全·无人机·边缘计算
hweiyu0031 分钟前
排序算法选型决策树
算法·排序算法
郑州光合科技余经理2 小时前
PHP构建:支撑欧美澳市场的同城生活服务平台开发
java·开发语言·数据库·uni-app·php·排序算法·生活
蓝色汪洋3 小时前
xtu oj矩阵
算法