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

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

相关文章

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

全网最全Tomcat完全卸载重装教程小结

《全网最全Tomcat完全卸载重装教程小结》windows系统卸载Tomcat重新通过ZIP方式安装Tomcat,优点是灵活可控,适合开发者自定义配置,手动配置环境变量后,可通过命令行快速启动和管理... 目录一、完全卸载Tomcat1. 停止Tomcat服务2. 通过控制面板卸载3. 手动删除残留文件4.

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例