二叉树的顺序存储

目录

顺序存储:

简介:

节点的位置关系:

优缺点:

优点:

缺点:

二叉树顺序存储的模拟实现:

向上调整算法:

向下调整算法:

二叉树的初始化:

直接初始化:

建堆初始化:

二叉树的头删:

二叉树的尾插:

二叉树的取顶端元素:

二叉树的判空:

二叉树的销毁:

完整代码:


顺序存储:

简介:

顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空间的浪费。而现实中使用中只有堆才会使用数组来存储,关于堆我们后面的章节会专门讲解。二叉树顺序存储在物理上是一个数组,在逻辑上是一颗二叉树。

节点的位置关系:

对于任意节点,设其在数组中的索引为 i(索引从0开始),则:

  • 父节点的索引为 (i-1)/2(向下取整)
  • 左子节点的索引为 2*i + 1
  • 右子节点的索引为 2*i + 2

优缺点:

优点

  • 访问任意节点的时间复杂度为O(1),因为可以直接通过索引访问。
  • 对于完全二叉树和满二叉树,空间利用率高。

缺点

  • 适用于完全二叉树或满二叉树,对于一般的二叉树,存在大量的空间浪费。
  • 插入和删除操作复杂,需要移动大量节点以保持树的顺序存储结构。

二叉树顺序存储的模拟实现:

向上调整算法:

void AdjustUp(HeapDataType* a, int child)
{int parent = (child - 1) / 2;while (child > 0){if (a[child] > a[parent]){Swap(&a[child], &a[parent]);child = parent;parent = (child - 1) / 2;}else{break;}}
}

向下调整算法:

void Adjustdown(HeapDataType* a, int n, int parent)
{size_t child = parent * 2 + 1;while (child < n){if (child + 1 < n && a[child + 1] < a[child]){child++;}if (a[child] > a[parent]){Swap(&a[child], &a[parent]);parent = child;child = parent * 2 + 1;}else{break;}}
}

二叉树的初始化:

直接初始化:

void HeapInit(HP* php)
{php->a = NULL;php->capacity = 0;php->size = 0;
}

建堆初始化:

void HeapInitArrey(HP* php, HeapDataType* a, int n)
{assert(php);php->a = (HeapDataType*)malloc(sizeof(HeapDataType) * n);if (php->a == NULL){perror("malloc fail:");return;}memcpy(php->a, a, sizeof(HeapDataType) * n);
}

二叉树的头删:

void HeapPop(HP* php)
{assert(php);assert(php->size > 0);Swap(&php->a[0], &php->a[php->size - 1]);php->size--;Adjustdown(php->a, php->size, 0);
}

二叉树的尾插:

void HeapPush(HP* php, HeapDataType x)
{if (php->size == php->capacity){size_t newcapacity = php->capacity == 0 ? 4 : 2 * php->capacity;HeapDataType* tmp = realloc(php->a, sizeof(HeapDataType) * newcapacity);php->a = tmp;php->capacity = newcapacity;}php->a[php->size] = x;php->size++;AdjustUp(php->a, php->size - 1);
}

二叉树的取顶端元素:

HeapDataType HeapTop(HP* php)
{assert(php);return php->a[0];
}

二叉树的判空:
 

bool Empty(HP* php)
{assert(php);return php->size == 0;
}

二叉树的销毁:

void HeapDestory(HP* php)
{free(php);php->a = NULL;php->capacity = 0; php->size = 0;
}

完整代码:

#include "heap.h"
void HeapInit(HP* php)
{php->a = NULL;php->capacity = 0;php->size = 0;
}void HeapInitArrey(HP* php, HeapDataType* a, int n)
{assert(php);php->a = (HeapDataType*)malloc(sizeof(HeapDataType) * n);if (php->a == NULL){perror("malloc fail:");return;}memcpy(php->a, a, sizeof(HeapDataType) * n);
}void HeapPush(HP* php, HeapDataType x)
{if (php->size == php->capacity){size_t newcapacity = php->capacity == 0 ? 4 : 2 * php->capacity;HeapDataType* tmp = realloc(php->a,sizeof(HeapDataType) * newcapacity);php->a = tmp;php->capacity = newcapacity;}php->a[php->size] = x;php->size++;AdjustUp(php->a, php->size - 1);
}void HeapPop(HP* php)
{assert(php);assert(php->size > 0);Swap(&php->a[0], &php->a[php->size - 1]);php->size--;Adjustdown(php->a, php->size, 0);
}void Swap(HeapDataType* x, HeapDataType* y)
{HeapDataType* tmp = *x;*x = *y;*y = tmp;
}void AdjustUp(HeapDataType* a, int child)
{int parent = (child - 1) / 2;while (child > 0){if (a[child] > a[parent]){Swap(&a[child], &a[parent]);child = parent;parent = (child - 1) / 2;}else{break;}}
}void Adjustdown(HeapDataType* a, int n, int parent)
{size_t child = parent * 2 + 1;while (child < n){if (child + 1 < n && a[child + 1] < a[child]){child++;}if (a[child] > a[parent]){Swap(&a[child], &a[parent]);parent = child;child = parent * 2 + 1;}else{break;}}
}HeapDataType HeapTop(HP* php)
{assert(php);return php->a[0];
}bool Empty(HP* php)
{assert(php);return php->size == 0;
}void HeapDestory(HP* php)
{free(php);php->a = NULL;php->capacity = 0; php->size = 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/41791.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

spdlog一个非常好用的C++日志库(五): 源码分析之registry类

目录 1.registry类意义 2.registry类实现 2.1.registry数据成员 2.2.registry函数成员 2.2.1.构造与析构 2.2.2.单例模式 2.2.3.全局注册表 2.2.4.initialize_logger初始化logger对象 2.2.5.全局格式器 2.2.6.预置日志等级 2.2.7.flush日志等级 2.2.8.默认logger …

合并区间(python3)

合并区间 题目描述解题思路代码实现复杂度 题目描述 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示…

认识流式处理框架Apache Flink

目录 一、Apache Flink 的基础概念 1.1 Apache Flink是什么&#xff1f; 1.2 Flink的定义 二、Apache Flink 的发展史 2.1 Flink前身Stratosphere 2.2 Flink发展时间线及重大变更 三、Flink核心特性 3.1 批流一体化 3.2 同时支持高吞吐、低延迟、高性能 3.3 支持事件时…

Git 运用小知识

1.Git添加未完善代码的解决方法 1.1 Git只是提交未推送 把未完善的代码提交到本地仓库 只需点击撤销提交&#xff0c;提交的未完善代码会被撤回 代码显示未提交状态 1.2 Git提交并推送 把未完善的代码提交并推送到远程仓库 点击【未完善提交并推送】的结点选择还原提交&#x…

指定版本ceph-common安装

如&#xff0c;安装15.2.13的ceph-common PACKAGE_NAMEceph-common CEPH_VERSION15.2.13 wget -q -O- https://download.ceph.com/keys/release.asc | sudo apt-key add - echo deb http://download.ceph.com/debian-${CEPH_VERSION}/ $(lsb_release -sc) main | sudo tee …

关于学习方法的优化

这是一种新的学习方法&#xff0c;一种新的学习形式&#xff0c;可以通过歌唱的方式&#xff0c;运用&#xff0c;把自己每天要进行的内容进行一个复习&#xff0c;进行一个重复&#xff0c;这样可以实现随时随地进行一个学习&#xff0c;这样可以帮助快速走出来&#xff01; 您…

面试记录总结

es6新特性 --------------------------------------------------------------------------------------- let 1.变量不能重复声明 2.块儿级作用域 3.不存在变量提升 4.不影响作用域链 const 1.一定要赋初始值 2.一般常量使用大写(潜规则) 3.常量的值不能修改 4.块儿级作用域 5…

MinIO - 从 环境搭建 -> SpringBoot实战 -> 演示,掌握 Bucket 和 Object 操作

目录 开始 Docker 部署 MinIO 中的基本概念 SpringBoot 集成 MinIO 依赖 配置 MinIO 时间差问题报错 The difference between the request time and the servers time is too large MinIO 中对 Bucket&#xff08;文件夹&#xff09; 的操作 是否存在 / 创建 查询所有…

如何产生一个有价值的观点

今天看了黄执中的一个课叫如何产生有价值的观点收获挺大的。 有价值指的是能让人听完有“哦”的提壶灌顶的感觉。而观点是指具有浅负担&#xff0c;深触动&#xff0c;可迁移属性的一个想法。 黄执中说这样的观点不是灵机一现&#xff0c;而是可以量产的。他给我举了三个计算…

Apache Seata 源码分析Seata-XID传递 Dubbo篇

本文来自 Apache Seata官方文档&#xff0c;欢迎访问官网&#xff0c;查看更多深度文章。 本文来自 Apache Seata官方文档&#xff0c;欢迎访问官网&#xff0c;查看更多深度文章。 源码分析 Seata-XID 传递 Dubbo 篇 本文作者&#xff1a;FUNKYE(陈健斌),杭州某互联网公司主…

TQ15EG开发板教程:MPSOC创建fmcomms8工程

链接&#xff1a;https://pan.baidu.com/s/1jbuYs9alP2SaqnV5fpNgyg 提取码&#xff1a;r00c 本例程需要实现在hdl加no-OS系统中&#xff0c;通过修改fmcomms8/zcu102项目&#xff0c;实现在MPSOC两个fmc口上运行fmcomms8项目。 目录 1 下载文件与切换版本 2 编译fmcomms8项…

超越YOLO! RT-DETR 实时目标检测技术介绍

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

基于STM32F103C8T6的同步电机驱动-电流环PI与力矩模式

基于STM32F103C8T6的同步电机驱动-电流环PI与力矩模式 本系列文章: 基于STM32F103C8T6的同步电机驱动-CubeMX配置与IQmath调用基于STM32F103C8T6的同步电机驱动-PWM驱动代码以及SVPWM的实现基于STM32F103C8T6的同步电机驱动-ADC采样与基于MT6701的角度获取基于STM32F103C8T6的…

JavaScript中的解构赋值:用途与优势

文章目录 JavaScript中的解构赋值&#xff1a;用途与优势一、简化数组和对象数据的访问数组解构对象解构 二、函数返回多个值三、与扩展运算符结合使用数组扩展对象扩展 四、默认值五、嵌套解构总结 JavaScript中的解构赋值&#xff1a;用途与优势 在JavaScript中&#xff0c;…

linux cpuspeed工具

cpuspeed 是一个用于管理和监控 CPU 频率的工具&#xff0c;主要用于基于 Linux 的系统。它可以帮助用户根据系统的负载自动调整 CPU 频率&#xff0c;以节省电能或提高性能。 以下是一些常见的 cpuspeed 用法及其配置示例&#xff1a; 安装 cpuspeed 在某些 Linux 发行版上…

免杀笔记 ----> DLL注入

这段时间我们暂时没什么事情干的话我们就继续更新我们的免杀笔记力&#xff01;&#xff01;&#xff01; &#xff1a;今天我们讲DLL注入 目录 1.DLL注入 2.直接加载DLL&#xff1f; 3.远程线程注入 获取Handle 远程申请内存空间 将我们的CS的DLL加载入内存 创建远程线…

02:C语言数据类型

C语言数据类型 1、整型变量2、浮点型变量3、字符型变量4、有符号数和无符号数 1、整型变量 #include <stdio.h>int main(void) { /* int a; //定义一个整型变量aint b; //定义一个整型变量bint c; //定义一个整型变量c */ /* int a,b,c; //也可以这样定义a 25;b 6; *…

Linux 服务器环境搭建

一、安装 JDK 官网下载地址&#xff1a;https://www.oracle.com/java/technologies/downloads # 创建目录 mkdir /usr/local/java/# 解压 tar -zxvf jdk-8u333-linux-x64.tar.gz -C /usr/local/java/# 配置环境变量 vim /etc/profileexport export JAVA_HOME/usr/local/java/…

【Linux】进程信号_4

文章目录 八、进程信号3. 信号的处理4. 可重入函数5. volatile 未完待续 八、进程信号 3. 信号的处理 当某个信号的处理函数被调用时&#xff0c;操作系统会自动将当前信号假如进程的信号屏蔽字当中。如果处理完该信号&#xff0c;该信号同样也会自动从信号屏蔽字中 移除。该…

马尔科夫假设

马尔科夫假设 马尔科夫假设&#xff08;Markov Assumption&#xff09;&#xff0c;也称为无记忆假设&#xff0c;它假设在给定当前状态的情况下&#xff0c;未来的状态只依赖于当前状态&#xff0c;而与过去的状态序列无关。在强化学习中&#xff0c;如果这个假设不成立&…