二叉堆的构建,上浮以及下沉

2023-10-19 02:10
文章标签 构建 二叉 上浮 下沉

本文主要是介绍二叉堆的构建,上浮以及下沉,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

二叉堆本质上就是完全二叉树,分为两类

  1. 最大堆,所有的父节点都大于或等于它的左右孩子节点
  2. 最小堆,所有的父节点都小于或等于它的左右孩子节点

以下代码都是以最小堆为例

二叉堆的操作

二叉堆虽然是一个完全二叉树,但是它的存储方式并不是链式存储,而是顺序存储,它所有的节点都存储在数组中。

父节点与孩子节点,父节点与父节点的父节点在数组中坐标的关系推导

在这里插入图片描述

插入节点

插入的节点存放在二叉堆的最后一个位置,然后将这个节点与它的父节点比较,不满足最小堆性质的就将二者交换,这就是“上浮”,再与新的父节点比较,直至上浮到正确位置

/*** 上浮 插入时用上浮* @param array 待调整的堆*/
public static void upAdjust(int[] array){int child = array.length-1;int parent = (child-1)/2;//存放插入的节点数值,用于最后交换int temp = array[child];while(child>0&&temp<array[parent]){//有了temp就不需要交换,只需覆盖最后跳出while时再把temp放在该放的位置array[child]=array[parent];//父节点变为孩子节点child = parent;// 父节点的父节点parent=(child-1)/2;}array[child]=temp;
}

删除节点

二叉堆所删除的是出于堆顶的节点,为了维持二叉树的结构,会将最后一个节点临时补到堆顶的位置,然后依次和左右孩子比较进行下沉操作。

/*** 下沉,删除时用下沉* @param array 堆* @param index 要下沉的父节点* @param length 堆的有效大小*/
public static  void downAdjust(int[] array,int index,int length){//左孩子节点int child = 2*index+1;//临时存放父节点的值用于最后的交换int temp=array[index];//判断是否存在左孩子节点while(child<length){//判断是否存在右孩子节点,并且右孩子节点并且左孩子节点大于右孩子节点if(child+1<length&&array[child]>array[child+1]){child++;}//判断父节点是否小于右孩子节点,小于就跳出if(temp<=array[child]){break;}// 与上浮一样不交换直接覆盖array[index] = array[child];index = child;child = index*2+1;}array[index] = temp;
}

构建二叉堆

构建二叉堆是将一个无序的完全二叉树调整为二叉堆,本质就是让所有的非叶子节点依次下沉。从二叉树的最后一个非叶子节点开始。

/*** 构建堆  将一个无序的完全二叉树调整为二叉堆,让所有的非叶子节点依次下沉* @param array*/
public static void buildHeap(int[] array){//从二叉堆最后一个非叶子节点开始,让所有非叶子节点依次下沉for (int i = (array.length-2)/2; i >=0 ; i--) {downAdjust(array,i,array.length);}
}

这篇关于二叉堆的构建,上浮以及下沉的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

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

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

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(