@@ -867,7 +867,50 @@ void quick_sort(int a[], int low, int high){
867
867
}
868
868
```
869
869
870
- 5 . 堆排序:假设序列有n个元素,先将这n建成大顶堆,然后取堆顶元素,与序列第n个元素交换,然后调整前n-1元素,使其重新成为堆,然后再取堆顶元素,与第n-1个元素交换,再调整前n-2个元素...直至整个序列有序。
870
+ 5 . 堆排序:将待排序序列构造成一个大顶堆,此时,整个序列的最大值就是堆顶的根节点。将其与末尾元素进行交换,此时末尾就为最大值。然后将剩余n-1个元素重新构造成一个堆,这样会得到n个元素的次小值。如此反复执行,便能得到一个有序序列了。
871
+ ``` java
872
+ public class Test {
873
+
874
+ public void sort (int [] arr ) {
875
+ for (int i = arr. length / 2 - 1 ; i >= 0 ; i-- ) {
876
+ adjustHeap(arr, i, arr. length);
877
+ }
878
+ for (int j = arr. length - 1 ; j > 0 ; j-- ) {
879
+ swap(arr, 0 , j);
880
+ adjustHeap(arr, 0 , j);
881
+ }
882
+
883
+ }
884
+
885
+ public void adjustHeap (int [] arr , int i , int length ) {
886
+ int temp = arr[i];
887
+ for (int k = i * 2 + 1 ; k < length; k = k * 2 + 1 ) {
888
+ if (k + 1 < length && arr[k] < arr[k + 1 ]) {
889
+ k++ ;
890
+ }
891
+ if (arr[k] > temp) {
892
+ arr[i] = arr[k];
893
+ i = k;
894
+ } else {
895
+ break ;
896
+ }
897
+ }
898
+ arr[i] = temp;
899
+ }
900
+
901
+ public void swap (int [] arr , int a , int b ) {
902
+ int temp = arr[a];
903
+ arr[a] = arr[b];
904
+ arr[b] = temp;
905
+ }
906
+
907
+ public static void main (String [] args ) {
908
+ int [] arr = {9 , 8 , 7 , 6 , 5 , 4 , 3 , 2 , 1 };
909
+ new Test (). sort(arr);
910
+ System . out. println(Arrays . toString(arr));
911
+ }
912
+ }
913
+ ```
871
914
6 . 希尔排序:先将整个待排记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录基本有序时再对全体记录进行一次直接插入排序。
872
915
7 . 归并排序:把有序表划分成元素个数尽量相等的两半,把两半元素分别排序,两个有序表合并成一个
873
916
0 commit comments