Maison  >  Article  >  Java  >  Comment trier rapidement les fonctions en Java

Comment trier rapidement les fonctions en Java

小老鼠
小老鼠original
2024-01-18 17:26:181217parcourir

快速排序方法:1、创建一个Java示例文件;2、通过quickSort方法实现快速排序算法;3、选择数组中的一个元素作为主元(pivot),并将数组分为两个子数组,一个包含比主元小的元素,另一个包含比主元大的元素,然后对这两个子数组递归地应用快速排序算法;4、在main方法中对数组进行了排序并输出结果即可。

Comment trier rapidement les fonctions en Java

本教程操作系统:windows10系统、Dell G3电脑。

以下是在Java中实现快速排序算法的示例代码:

public class QuickSort {
    public static void quickSort(int[] arr, int low, int high) {
        if (arr == null || arr.length == 0) {
            return;
        }
        if (low >= high) {
            return;
        }
        int middle = low + (high - low) / 2;
        int pivot = arr[middle];
        int i = low, j = high;
        while (i <= j) {
            while (arr[i] < pivot) {
                i++;
            }
            while (arr[j] > pivot) {
                j--;
            }
            if (i <= j) {
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
                i++;
                j--;
            }
        }
        if (low < j) {
            quickSort(arr, low, j);
        }
        if (high > i) {
            quickSort(arr, i, high);
        }
    }
    public static void main(String[] args) {
        int[] arr = {5, 2, 8, 3, 9, 1};
        quickSort(arr, 0, arr.length - 1);
        for (int num : arr) {
            System.out.print(num + " ");
        }
    }
}

在上面的示例中,quickSort方法实现了快速排序算法。该算法选择数组中的一个元素作为主元(pivot),并将数组分为两个子数组,一个包含比主元小的元素,另一个包含比主元大的元素。然后对这两个子数组递归地应用快速排序算法。最后在main方法中对数组进行了排序并输出结果。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn