Java 快速排序

快速排序(Quicksort)是一种高效的排序算法,采用分治法(Divide and Conquer)的策略来把一个序列分为较小和较大的两个子序列,然后递归地排序两个子序列。以下是用Java实现的快速排序算法:

复制代码
public class QuickSort {  
  
    // 主方法,用于测试快速排序  
    public static void main(String[] args) {  
        int[] array = {10, 7, 8, 9, 1, 5};  
        int n = array.length;  
  
        System.out.println("排序前的数组:");  
        printArray(array);  
  
        quickSort(array, 0, n-1);  
  
        System.out.println("排序后的数组:");  
        printArray(array);  
    }  
  
    // 快速排序方法  
    public static void quickSort(int[] array, int low, int high) {  
        if (low < high) {  
            // 找到分区点  
            int pi = partition(array, low, high);  
  
            // 递归地对左右子数组排序  
            quickSort(array, low, pi - 1);  
            quickSort(array, pi + 1, high);  
        }  
    }  
  
    // 分区方法  
    public static int partition(int[] array, int low, int high) {  
        int pivot = array[high];  // 选择最右边的元素作为枢轴  
        int i = (low - 1);  // i是较小元素的索引  
  
        for (int j = low; j < high; j++) {  
            // 如果当前元素小于或等于枢轴  
            if (array[j] <= pivot) {  
                i++;  
  
                // 交换array[i]和array[j]  
                int temp = array[i];  
                array[i] = array[j];  
                array[j] = temp;  
            }  
        }  
  
        // 交换array[i + 1]和array[high] (或枢轴)  
        int temp = array[i + 1];  
        array[i + 1] = array[high];  
        array[high] = temp;  
  
        return i + 1;  
    }  
  
    // 打印数组方法  
    public static void printArray(int[] array) {  
        int n = array.length;  
        for (int i = 0; i < n; ++i) {  
            System.out.print(array[i] + " ");  
        }  
        System.out.println();  
    }  
}

代码解释

  1. 主方法 (main) :
    • 创建一个数组并输出排序前的数组。
    • 调用 quickSort 方法对数组进行排序。
    • 输出排序后的数组。
  2. 快速排序方法 (quickSort) :
    • 如果 low 小于 high,则进行排序。
    • 调用 partition 方法获取分区点 pi
    • 递归地对分区点前后的子数组进行排序。
  3. 分区方法 (partition) :
    • 选择数组的最后一个元素作为枢轴。
    • 初始化较小元素的索引 i
    • 遍历数组,如果当前元素小于或等于枢轴,则交换 array[i]array[j]
    • 遍历完成后,将枢轴放到正确的位置(即 i + 1),并返回该位置。
  4. 打印数组方法 (printArray) :
    • 遍历数组并打印每个元素。

注意事项

  • 枢轴的选择可以优化,例如随机选择枢轴或选择数组的中间元素作为枢轴,以减少最坏情况(例如已经有序的数组)下的性能下降。
  • 快速排序的空间复杂度主要是递归调用栈,最坏情况下为 O(n),但平均情况下较好。
  • 快速排序的时间复杂度平均情况下为 O(n log n),最坏情况下为 O(n^2)。
相关推荐
阿正的梦工坊13 小时前
【Rust】03-所有权、移动与复制
开发语言·算法·rust
一切皆是因缘际会13 小时前
因果推理人工智能
大数据·数据结构·人工智能
好评笔记13 小时前
深度学习面试八股—— GRU(Gated Recurrent Unit)
人工智能·rnn·深度学习·算法·机器学习·gru·校招
搞科研的小刘选手13 小时前
【智能计算方向专题研讨会】第三届智能计算与数据分析国际学术会议(ICDA 2026)
大数据·算法·机器学习·数据挖掘·数据分析·可视化·计算
量化君也13 小时前
桥水基金全天候策略拆解,构建中国ETF躺平版策略
大数据·人工智能·python·算法·金融·业界资讯
蓦然回首却已人去楼空13 小时前
画图专用文档
算法
洛水水13 小时前
【力扣100题】78.在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
江屿风13 小时前
C++图论基础拓扑排序算法流食般投喂
开发语言·c++·笔记·算法·排序算法
海棠AI实验室14 小时前
AI 时代文献综述:从检索到成稿的 RAG 五步法
windows·算法·自动化·llm·rag
H1785350909614 小时前
SolidWorks_基于草图的实体特征14_扫描扭转与控制
前端·人工智能·算法·3d建模·solidworks