package cn.tan.heap;
//建立小堆的过程
public class HeapTest {
public static void shiftDown(long[] arr,int size,int index){
while(true){
int left=2*index+1;
//先判定左节点
if(left>=size){
return;
}
int right=left+1;
int min=left;
//在判定右节点
if(right<size&&arr[right]<arr[left]){
min=right;
}
//在比较双亲和孩子的大小
if(arr[index]<=arr[min]){
return;
}
swap(arr,min,index);
index=min;
}
}
private static void swap(long[] arr, int min, int index) {
long t = arr[index];
arr[index] = arr[min];
arr[min] = t;
}
//建堆这里就是建一个小堆就是对一个数组进行调整
public static void createHeap(long[] arr,int size){
//叶节点是不用进行向下调整的
for(int i=(size-2)/2;i>=0;i--){
shiftDown(arr,size,i);
}
}
public static void main(String[] args) {
// long[] array = { 2, 5, 1, 7, 13, 3, 5, 9, 8 };
// long[] array = { 27, 15, 19, 18, 28, 34, 65, 49, 25, 37 };
long[] array = {1, 9, 1, 7, 2, 3, 2, 8, 5, 4, 3, 0, 1};
createHeap(array, array.length);
}
}
1.向下调整是当前节点与两个孩子中最值的比较
2.建堆的过程其实就是对数组进行调整的过程