0

0

Java中快速排序的原理 图解快速排序的分治思想实现

穿越時空

穿越時空

发布时间:2025-06-19 16:09:02

|

579人浏览过

|

来源于php中文网

原创

快速排序的核心在于分治思想,通过选取基准值将数组分为两个子数组并递归排序。1. 选择基准值(如首元素、随机或三数取中),2. 分区使小于基准值的在左、大于的在右,3. 递归对左右子数组排序。其平均时间复杂度为o(n log n),但最坏情况下可能退化到o(n^2)。相比其他算法,快速排序效率高且空间占用少,但不稳定且最坏性能较差,适用于大数据集且可接受不稳定的场景。

Java中快速排序的原理 图解快速排序的分治思想实现

快速排序的核心在于分治思想,通过选取一个基准值,将数组划分为两个子数组,小于基准值的放在左边,大于基准值的放在右边,然后递归地对这两个子数组进行排序。

Java中快速排序的原理 图解快速排序的分治思想实现

快速排序是一种高效的排序算法,尤其在处理大数据集时表现出色。它的平均时间复杂度为O(n log n),但在最坏情况下可能退化到O(n^2)。理解快速排序的关键在于掌握其分治思想和基准值的选取。

Java中快速排序的原理 图解快速排序的分治思想实现

快速排序算法步骤详解

  1. 选择基准值(Pivot): 从数组中选取一个元素作为基准值。选择策略会影响算法的性能,常见的有选择第一个元素、最后一个元素或随机选择。

    立即学习Java免费学习笔记(深入)”;

    Java中快速排序的原理 图解快速排序的分治思想实现
  2. 分区(Partitioning): 重新排列数组,使得所有小于基准值的元素都移动到基准值左边,所有大于基准值的元素都移动到基准值右边。基准值位于其最终排序位置。

  3. 递归排序: 递归地对基准值左右两边的子数组进行快速排序。

让我们用一个例子来说明:假设有数组 [7, 2, 1, 6, 8, 5, 3, 4],我们选择第一个元素 7 作为基准值。

  • 经过分区操作后,数组可能变为 [2, 1, 6, 5, 3, 4, 7, 8]。可以看到,所有小于 7 的元素都在左边,所有大于 7 的元素都在右边,7 已经位于其最终位置。

  • 然后,我们分别对 [2, 1, 6, 5, 3, 4][8] 这两个子数组进行递归排序。

如何选择合适的基准值以优化快速排序性能?

基准值的选择对快速排序的性能至关重要。理想情况下,基准值应该尽可能地将数组分成大小相等的两部分。以下是一些常见的基准值选择策略:

海螺音乐
海螺音乐

海螺AI推出的AI音乐生成工具,可以生成个性化的音乐作品。

下载
  • 选择第一个元素或最后一个元素: 这是最简单的策略,但如果数组已经部分有序,会导致最坏情况的发生,时间复杂度退化到O(n^2)。

  • 随机选择: 随机选择基准值可以有效地避免最坏情况的发生,平均性能较好。

  • 三数取中: 从数组的第一个、中间和最后一个元素中选择大小居中的元素作为基准值。这种方法在一定程度上可以避免选择到极端值。

实际应用中,可以根据数据特点选择合适的基准值选择策略。如果数据分布均匀,随机选择可能是一个不错的选择。如果数据可能已经部分有序,三数取中可能更合适。

快速排序的Java代码实现示例

下面是一个简单的快速排序的Java代码实现:

public class QuickSort {

    public static void quickSort(int[] arr, int low, int high) {
        if (low < high) {
            int pivotIndex = partition(arr, low, high);

            quickSort(arr, low, pivotIndex - 1);
            quickSort(arr, pivotIndex + 1, high);
        }
    }

    private static int partition(int[] arr, int low, int high) {
        int pivot = arr[low];
        int i = low + 1;
        int j = high;

        while (i <= j) {
            while (i <= high && arr[i] <= pivot) {
                i++;
            }

            while (j >= low && arr[j] > pivot) {
                j--;
            }

            if (i < j) {
                swap(arr, i, j);
                i++;
                j--;
            } else {
                break;
            }
        }
        swap(arr, low, j);
        return j;
    }

    private static void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }

    public static void main(String[] args) {
        int[] arr = {7, 2, 1, 6, 8, 5, 3, 4};
        quickSort(arr, 0, arr.length - 1);

        for (int num : arr) {
            System.out.print(num + " ");
        }
    }
}

这段代码首先定义了quickSort方法,用于递归地对数组进行排序。partition方法用于将数组划分为两个子数组,并返回基准值的索引。swap方法用于交换数组中两个元素的位置。

快速排序与其他排序算法相比有哪些优缺点?

与其他排序算法相比,快速排序的优点在于其平均时间复杂度为O(n log n),并且是原地排序算法,不需要额外的存储空间(除了递归调用栈)。缺点在于最坏情况下时间复杂度会退化到O(n^2),并且不稳定(相同元素的相对位置可能会改变)。

与归并排序相比,快速排序通常更快,因为其常数因子更小。但归并排序是稳定的,并且最坏情况下时间复杂度仍然是O(n log n)。

冒泡排序、插入排序等简单排序算法相比,快速排序在大数据集上的性能优势非常明显。但对于小数据集,简单排序算法可能更快,因为其常数因子更小。

选择哪种排序算法取决于具体的应用场景。如果需要稳定的排序,或者对最坏情况下的性能有严格要求,归并排序可能更合适。如果对性能要求较高,并且可以接受不稳定性,快速排序通常是一个不错的选择。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

397

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

411

2023.08.14

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

4

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

1

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

1

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

16

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 5万人学习

Go 教程
Go 教程

共32课时 | 4.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号