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メソッドを呼び出し、最後にソートされた配列を出力しています。