大頂堆 Java部分實現

轉載自 https://blog.csdn.net/sunlei_secret/article/details/68486452java

 

 

//java 大頂堆的簡單實現
import java.util.Arrays;
public class Heap{
public void heapSort(int[] num){
  int n = num.length;
  for(int i = n/2;i>=0;i--){ //建堆,從n/2開始向上調整
    adjustHeap(num, i, n);
  }
  
for(int j=n-1;j>=0;j--){     swap(num,0, j); //交換開始和最後位置上的數字     adjustHeap(num, 0, j); //交換以後再調整堆   } }
public void adjustHeap(int[] num,int s,int n){ //因爲根節點編號是從0開始的,因此其左子樹是2*i+1   for(int i=s;i<n;){     int max = i;     if((2*i+1)<n&&num[2*i+1]>num[max]) max = 2*i+1;     if((2*i+2)<n&&num[2*i+2]>num[max]) max = 2*i+2;     if(max!=i){         swap(num,i,max);         i=max;     }else break;   } }
public void swap(int[] num,int i,int j){   int tem = num[i];   num[i] = num[j];   num[j] = tem; }
public static void main(String[] args) {   Heap heap = new Heap();   int[] num = new int[]{49,38,65,97,76,13,27,49};   heap.heapSort(num);   System.out.println(Arrays.toString(num));   } }
相關文章
相關標籤/搜索