Javaでクイックソートを実装する方法は何ですか?

クイックソートは、一般的に使用されるソートアルゴリズムで、アイデアは基準値を選択し、配列を2つの部分に分け、左側の部分はすべての要素が基準値より小さく、右側の部分はすべての要素が基準値より大きいようにします。そして、それぞれの左右の部分に再帰的にクイックソートを行います。以下はクイックソートを実装する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;
        }

        // Choose the pivot element
        int middle = low + (high - low) / 2;
        int pivot = arr[middle];

        // Make left < pivot and right > pivot
        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--;
            }
        }

        // Recursively sort two sub-parts
        if (low < j) {
            quickSort(arr, low, j);
        }
        if (high > i) {
            quickSort(arr, i, high);
        }
    }

    public static void main(String[] args) {
        int[] arr = {6, 3, 8, 2, 9, 1};
        quickSort(arr, 0, arr.length - 1);
        System.out.println("Sorted array: " + Arrays.toString(arr));
    }
}

上記のコードでは、quickSortメソッドを使用してクイックソートを実装しており、lowは配列の最初の位置、highは配列の最後の位置を表しています。mainメソッドでは、配列arrを定義し、それをソートするためにquickSortメソッドを呼び出し、最後にソートされた配列を出力しています。

コメントを残す 0

Your email address will not be published. Required fields are marked *