下面是一个基本的堆排序的Java代码示例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
| import java.util.Arrays;
public class HeapSort {
public static void heapSort(int[] arr) { int n = arr.length;
for (int i = n / 2 - 1; i >= 0; i--) { heapify(arr, n, i); }
for (int i = n - 1; i > 0; i--) { int temp = arr[0]; arr[0] = arr[i]; arr[i] = temp;
heapify(arr, i, 0); } }
private static void heapify(int[] arr, int n, int root) { int largest = root; int left = 2 * root + 1; int right = 2 * root + 2;
if (left < n && arr[left] > arr[largest]) { largest = left; }
if (right < n && arr[right] > arr[largest]) { largest = right; }
if (largest != root) { int temp = arr[root]; arr[root] = arr[largest]; arr[largest] = temp;
heapify(arr, n, largest); } }
public static void main(String[] args) { int[] arr = {12, 11, 13, 5, 6, 7}; System.out.println("Original array: " + Arrays.toString(arr));
heapSort(arr);
System.out.println("Sorted array: " + Arrays.toString(arr)); } }
|
在这个示例中,heapSort
方法使用堆排序算法对整数数组进行排序。首先,构建一个最大堆,然后将根节点(最大值)与最后一个节点交换,然后再重新堆化剩余的部分。重复这个过程,直到整个数组有序。