legongju.com
我们一直在努力
2025-01-10 09:32 | 星期五

Java快速排序的代码优化

在Java中,实现快速排序算法的一个常见方法是递归。为了优化这段代码,我们可以使用以下策略:

  1. 选择更好的基准值(pivot):使用三数取中法或者随机选择基准值,这样可以减少不平衡分区的可能性,从而提高算法的性能。
  2. 尾递归优化:在递归调用时,先处理较小的分区,这样可以减少递归栈的深度,从而减少内存消耗。
  3. 当分区大小小于某个阈值时,使用简单的排序算法(如插入排序)处理分区,这样可以提高小规模数据集的处理速度。

下面是一个优化后的Java快速排序实现:

public class QuickSort {
    private static final int INSERTION_SORT_THRESHOLD = 47;

    public static void quickSort(int[] arr) {
        if (arr == null || arr.length <= 1) {
            return;
        }
        quickSort(arr, 0, arr.length - 1);
    }

    private static void quickSort(int[] arr, int low, int high) {
        while (low< high) {
            if (high - low + 1 <= INSERTION_SORT_THRESHOLD) {
                insertionSort(arr, low, high);
                break;
            }
            int pivotIndex = partition(arr, low, high);
            if (pivotIndex - low< high - pivotIndex) {
                quickSort(arr, low, pivotIndex - 1);
                low = pivotIndex + 1;
            } else {
                quickSort(arr, pivotIndex + 1, high);
                high = pivotIndex - 1;
            }
        }
    }

    private static int partition(int[] arr, int low, int high) {
        int mid = low + (high - low) / 2;
        int pivot = medianOfThree(arr, low, mid, high);
        swap(arr, pivot, high);
        int i = low - 1;
        for (int j = low; j< high; j++) {
            if (arr[j] <= arr[high]) {
                i++;
                swap(arr, i, j);
            }
        }
        swap(arr, i + 1, high);
        return i + 1;
    }

    private static int medianOfThree(int[] arr, int low, int mid, int high) {
        if (arr[low] > arr[mid]) {
            swap(arr, low, mid);
        }
        if (arr[low] > arr[high]) {
            swap(arr, low, high);
        }
        if (arr[mid] > arr[high]) {
            swap(arr, mid, high);
        }
        return mid;
    }

    private static void insertionSort(int[] arr, int low, int high) {
        for (int i = low + 1; i <= high; i++) {
            int key = arr[i];
            int j = i - 1;
            while (j >= low && arr[j] > key) {
                arr[j + 1] = arr[j];
                j--;
            }
            arr[j + 1] = key;
        }
    }

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

这个实现首先定义了一个阈值INSERTION_SORT_THRESHOLD,当分区大小小于这个阈值时,使用插入排序处理分区。在partition方法中,我们使用了三数取中法来选择基准值。在递归调用时,我们先处理较小的分区,以减少递归栈的深度。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/95125.html

相关推荐

  • 如何配置和使用Actuator Java

    如何配置和使用Actuator Java

    Actuator Java是一个用于监控和管理Java应用程序的库 添加依赖项 在您的项目中,您需要将Actuator Java库添加到构建系统中。以下是Maven和Gradle的示例:
    M...

  • nvl函数在Java中的作用是什么

    nvl函数在Java中的作用是什么

    在 Java 中,没有名为 “nvl” 的内置函数。但根据您的问题,我猜您可能想了解 NVL 函数在 SQL 语言中的作用,以及如何在 Java 中实现类似的功能。
    NVL 函数...

  • Java中的nvl函数如何使用

    Java中的nvl函数如何使用

    在 Java 中,没有内置的 nvl 函数(这个函数通常在 SQL 和 PL/SQL 中使用)。但是,你可以使用 Java 8 引入的 Optional 类来实现类似的功能。
    下面是一个简...

  • 如何在Java中使用nvl函数进行数据清洗

    如何在Java中使用nvl函数进行数据清洗

    在 Java 中,没有内置的 nvl 函数(这个函数通常在 SQL 和 PL/SQL 中使用)
    public class NVLExample { public static void main(String[] args) { String ...

  • 快速排序在Java中的应用场景

    快速排序在Java中的应用场景

    快速排序(Quick Sort)是一种高效的排序算法,适用于各种应用场景。以下是一些常见的Java应用场景: 数组排序:当需要对一个数组进行排序时,可以使用快速排序。...

  • Java快速排序的效率分析

    Java快速排序的效率分析

    快速排序(Quick Sort)是一种高效的排序算法,其基本思想是通过选取一个基准元素,将数组分为两部分,使得左边的元素都小于等于基准元素,右边的元素都大于等于...

  • 如何用Java编写快速排序算法

    如何用Java编写快速排序算法

    快速排序是一种高效的排序算法,它使用分治策略将一个数组分为两个较小的子数组,然后递归地对这些子数组进行排序
    public class QuickSort { public static...

  • Java中快速排序的实现原理

    Java中快速排序的实现原理

    快速排序(Quick Sort)是一种高效的排序算法,其基本思想是通过选取一个基准元素,将数组分为两部分,使得一部分的元素都小于基准元素,另一部分的元素都大于基...