当前位置: 首页 > article >正文

快速排序的基本思想和java实现

快速排序是一种常用的排序算法,基本思想是通过一趟排序将待排序的数据分割成独立的两部分,其中一部分的数据都比另一部分小,然后再对这两部分数据进行排序,直到整个序列有序。

具体的实现步骤如下:

  1. 选择一个基准元素,一般选择第一个元素作为基准。
  2. 将序列进行划分,将比基准元素小的元素放在基准元素的左边,比基准元素大的元素放在基准元素的右边。
  3. 对左右两个子序列进行递归排序。

下面是基于Java语言的快速排序实现代码:

public class QuickSort {
    
    public static void quickSort(int[] arr) {
        if (arr == null || arr.length == 0) {
            return;
        }
        quickSort(arr, 0, arr.length - 1);
    }
    
    private static void quickSort(int[] arr, int low, int high) {
        if (low >= high) {
            return;
        }
        int pivot = partition(arr, low, high); // 划分操作
        quickSort(arr, low, pivot - 1); // 对左子序列进行递归排序
        quickSort(arr, pivot + 1, high); // 对右子序列进行递归排序
    }
    
    private static int partition(int[] arr, int low, int high) {
        int pivot = arr[low]; // 选择第一个元素作为基准
        while (low < high) {
            while (low < high && arr[high] >= pivot) {
                high--;
            }
            arr[low] = arr[high]; // 将比基准小的元素移到左边
            while (low < high && arr[low] <= pivot) {
                low++;
            }
            arr[high] = arr[low]; // 将比基准大的元素移到右边
        }
        arr[low] = pivot; // 基准元素归位
        return low;
    }

    public static void main(String[] args) {
        int[] arr = {6, 3, 9, 1, 4, 7, 2, 8, 5};
        quickSort(arr);
        for (int num : arr) {
            System.out.print(num + " ");
        }
    }
}

以上代码中的quickSort方法是快速排序的入口方法,它首先判断数组是否为空或长度为0,如果是,则直接返回。然后调用quickSort方法对整个序列进行排序。

quickSort方法中递归调用了partition方法,用于划分序列。partition方法首先选择第一个元素作为基准,然后通过两个指针lowhigh在序列中进行左右扫描,找到比基准小的元素和比基准大的元素,交换它们的位置。然后将基准元素归位,并返回基准元素的位置。

最后,在main方法中测试了一个例子,输出排序后的结果。

快速排序的平均时间复杂度为O(nlogn),最坏情况下为O(n^2),空间复杂度为O(logn)。


http://www.kler.cn/a/428195.html

相关文章:

  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.30 性能巅峰:NumPy代码优化全攻略
  • SpringBoot源码解析(八):Bean工厂接口体系
  • Python NumPy(7):连接数组、分割数组、数组元素的添加与删除
  • 具身智能研究报告
  • 使用Redis生成全局唯一ID示例
  • 5分钟带你获取deepseek api并搭建简易问答应用
  • Next.js系统性教学:全面掌握客服务端组件(Server Components)
  • ARMv8-A MacOS调试环境搭建
  • Python毕业设计选题:基于大数据的淘宝电子产品数据分析的设计与实现-django+spark+spider
  • PyCharm文件、临时文件、目录、文件夹(Directory)、软件包(Package)的区别
  • Spring Boot配置文件敏感信息加密
  • 智创 AI 新视界 -- AI 与量子计算的未来融合前景(16 - 5)
  • python拆分Excel文件
  • docker安装ddns-go(外网连接局域网)
  • JVM 参数配置详细介绍
  • C++ Learning 函数重载•引用
  • PyTorch基本使用——张量的索引操作
  • opencv光流法推测物体的运动
  • Spring Boot日志:从Logger到@Slf4j的探秘
  • ChatGPT 最新推出的 Pro 订阅计划,具备哪些能力 ?
  • uniapp 微信小程序webview 和 h5数据通信
  • 【AWS re:Invent 2024】一文了解EKS新功能:Amazon EKS Auto Mode
  • Python实现BBS论坛自动签到【steamtools论坛】
  • Python 入门教程(2)搭建环境 | 2.4、VSCode配置Node.js运行环境
  • 如何利用DBeaver配置连接MongoDB和人大金仓数据库
  • django 实战(python 3.x/django 3/sqlite)