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

2023-11-22 19:59

本文主要是介绍利用完全二叉树的性质,如何创建一个大根堆和一个小根堆?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大根堆

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

分析如下:

假设对{ 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;}
}

这篇关于利用完全二叉树的性质,如何创建一个大根堆和一个小根堆?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/412547

相关文章

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Macos创建python虚拟环境的详细步骤教学

《Macos创建python虚拟环境的详细步骤教学》在macOS上创建Python虚拟环境主要通过Python内置的venv模块实现,也可使用第三方工具如virtualenv,下面小编来和大家简单聊聊... 目录一、使用 python 内置 venv 模块(推荐)二、使用 virtualenv(兼容旧版 P

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Java 如何创建和使用ExecutorService

《Java如何创建和使用ExecutorService》ExecutorService是Java中用来管理和执行多线程任务的一种高级工具,可以有效地管理线程的生命周期和任务的执行过程,特别是在需要处... 目录一、什么是ExecutorService?二、ExecutorService的核心功能三、如何创建

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设