利用完全二叉树的性质,如何创建一个大根堆和一个小根堆?

编程入门 行业动态 更新时间:2024-10-27 02:24:37

利用完全二叉树的性质,如何<a href=https://www.elefans.com/category/jswz/34/1771345.html style=创建一个大根堆和一个小根堆?"/>

利用完全二叉树的性质,如何创建一个大根堆和一个小根堆?

大根堆

大根堆:每个结点的值不大于他的父亲结点的值

分析如下:

假设对{ 27,15,19,18,28,34,65,49,25,37 }这样一个集合的数据创建成堆;

 

 

代码如下:

//建立大根堆
public class TestHeap{public int[] array;public int usedSize;//当前有效数组长度public TestHeap(){this.array = new int[10];this.usedSize = 0;}//初始化数组public void InitArray(int[] arrayClone){array = Arrays.copyOf(arrayClone, arrayClone.length);usedSize = array.length;}//创建大根堆public void createHeap(){for(int parent = (usedSize - 1 - 1) / 2; parent >= 0; parent--){adjustment(parent, usedSize);}}//调整public void adjustment(int parent, int len){//左子树结点下标int child = parent * 2 + 1;//调整while(child < len){//先判断有没有右孩子,如果右,找出最大值if(child + 1 < len && array[child] < array[child + 1]){child++;//如果右子树大,child++就指向他,如果左子树大,就不用管,直接进行下一步判断交换}//若左右子树的最大值大于父亲结点则交换if(array[child] > array[parent]){swap(array, child, parent);parent = child;child = parent * 2 + 1;} else{break;}}}//交换public void swap(int[] array, int child, int parent){int tmp = array[child];array[child] = array[parent];array[parent] = tmp;}
}

小根堆

小根堆:每个结点的值不小于他的父亲结点的值

     分析与大根堆类似,只是比较出更小的进行替换

代码如下:

//建立大根堆
public class TestHeap{public int[] array;public int usedSize;//当前有效数组长度public TestHeap(){this.array = new int[10];this.usedSize = 0;}//初始化数组public void InitArray(int[] arrayClone){array = Arrays.copyOf(arrayClone, arrayClone.length);usedSize = array.length;}//创建大根堆public void createHeap(){for(int parent = (usedSize - 1 - 1) / 2; parent >= 0; parent--){adjustment(parent, usedSize);}}//调整public void adjustment(int parent, int len){//左子树结点下标int child = parent * 2 + 1;//调整while(child < len){//先判断有没有右孩子,如果右,找出最小值if(child + 1 < len && array[child] > array[child + 1]){child++;//如果右子树小,child++就指向他,如果左子树小,就不用管,直接进行下一步判断交换}//若左右子树的最大值小于父亲结点则交换if(array[child] < array[parent]){swap(array, child, parent);parent = child;child = parent * 2 + 1;} else{break;}}}//交换public void swap(int[] array, int child, int parent){int tmp = array[child];array[child] = array[parent];array[parent] = tmp;}
}

更多推荐

利用完全二叉树的性质,如何创建一个大根堆和一个小根堆?

本文发布于:2024-02-08 20:52:49,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1674916.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:创建一个   性质   二叉树   小根堆   大根堆

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!