java实现快速排序(详细解释代码和逻辑)

简介: java实现快速排序(详细解释代码和逻辑)

快速排序(QuickSort)是一种高效的排序算法,平均时间复杂度为O(n log n),最坏情况下为O(n^2)。它通过分治法将数组分为较小的子数组来排序。

快速排序代码实现

public class QuickSort {
    // 主方法,用于调用快速排序方法
    public static void main(String[] args) {
        int[] array = {34, 7, 23, 32, 5, 62};
        quickSort(array, 0, array.length - 1);
        for (int i : array) {
            System.out.print(i + " ");
        }
    }
 
    // 快速排序方法
    public static void quickSort(int[] array, int low, int high) {
        if (low < high) {
            int pivotIndex = partition(array, low, high); // 获取划分点
            quickSort(array, low, pivotIndex - 1);  // 对左子数组进行递归排序
            quickSort(array, pivotIndex + 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] (或pivot)
        int temp = array[i + 1];
        array[i + 1] = array[high];
        array[high] = temp;
 
        return i + 1; // 返回划分点索引
    }
}

示例1:对整数数组进行排序

在主方法中,创建了一个整数数组并调用了quickSort方法对其进行排序。以下是代码的详细解释:

数组初始化:

int[] array = {34, 7, 23, 32, 5, 62};

调用快速排序方法:

quickSort(array, 0, array.length - 1);

打印排序后的数组:

1. for (int i : array) {
2.     System.out.print(i + " ");
3. }
  1. 这段代码遍历排序后的数组并打印每个元素。

代码解释

快速排序方法

public static void quickSort(int[] array, int low, int high) {
    if (low < high) {
        int pivotIndex = partition(array, low, high); // 获取划分点
        quickSort(array, low, pivotIndex - 1);  // 对左子数组进行递归排序
        quickSort(array, pivotIndex + 1, high); // 对右子数组进行递归排序
    }
}
  • quickSort方法接收三个参数:待排序数组array,子数组的起始索引low和结束索引high
  • 如果low小于high,说明子数组内至少有两个元素需要排序。
  • 调用partition方法获取划分点pivotIndex,然后递归调用quickSort对左子数组和右子数组进行排序。

划分方法

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] (或pivot)
    int temp = array[i + 1];
    array[i + 1] = array[high];
    array[high] = temp;
 
    return i + 1; // 返回划分点索引
}

partition方法接收三个参数:待划分数组array,子数组的起始索引low和结束索引high。

选择子数组的最后一个元素作为枢纽元素pivot。

初始化索引i为low - 1,用于记录小于或等于枢纽元素的区域。

遍历子数组中的每个元素,如果当前元素array[j]小于或等于枢纽元素,则将其与array[i]交换位置。

最后,将枢纽元素放置在正确的位置,并返回其索引。


相关文章
|
28天前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
320 4
|
2月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
356 3
|
2月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
250 3
|
2月前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
191 3
|
1月前
|
Java 数据处理 API
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
231 115
|
1月前
|
安全 Java 编译器
为什么你的Java代码需要泛型?类型安全的艺术
为什么你的Java代码需要泛型?类型安全的艺术
169 98
|
2月前
|
Java
java入门代码示例
本文介绍Java入门基础,包含Hello World、变量类型、条件判断、循环及方法定义等核心语法示例,帮助初学者快速掌握Java编程基本结构与逻辑。
377 0
|
3月前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
122 2
|
1月前
|
安全 Java 容器
告别繁琐判空:Optional让你的Java代码更优雅
告别繁琐判空:Optional让你的Java代码更优雅