【数据结构10】满/完全二叉树、顺序/链式存储

目录

一、满二叉树

二、完全二插树

[2.1 完全二叉树特点](#2.1 完全二叉树特点)

三、任意二叉树性质

(1)第i层上节点数最多为2^(i-1)

[(2)高度为h的二叉树最多节点数为2^h - 1](#(2)高度为h的二叉树最多节点数为2^h - 1)

(3)叶子节点数量等于度为2的节点数量+1

(4)有n个节点的完全二叉树高度为多少?

四、顺序/链式存储🤯🤯🤯

[4.1 顺序存储](#4.1 顺序存储)

[4.2 链式存储](#4.2 链式存储)

(1)深度搜索过程

(2)广度搜索过程

(3)根据遍历结果重构二叉树题目


一、满二叉树

每个节点都有两个元素

上图满二叉树的高度为4,根据公式2^h-1可计算出有15个节点

**2^(i-1)**计算得出1-4层分别有1、2、4、8个节点

二、完全二插树

一共给了10(<15)个元素,无法构成满二叉树,故从上到下,从左到右

形成完全二叉树

2.1 完全二叉树特点

三、任意二叉树性质

(1)第i层上节点数最多为2^(i-1)

就是满二叉树以下,结合满二叉树公式来理解

(2)高度为h的二叉树最多节点数为2^h - 1
(3)叶子节点数量等于度为2的节点数量+1

总的节点数 == 度为0的节点 + 度为1的节点 + 度为2的节点 == n0 + n1 + n2

且观察以上完全二叉树的图,发现一根连接线对应一个节点,除了根节点,于是

总的节点数 == 总链接线 + 1(根节点)

== 度为0节点(0线)+ 度为1的节点(1根线)+ 度为2的节点(2根线)+ 1

== n0(0) + n1 + 2*n2 + 1

故n0 + n1 + n2 == n1 + 2*n2 + 1

化简得: n0 = n2 + 1

(4)有n个节点的完全二叉树高度为多少?

设高度为h

2 ^ h -1 == n

2 ^ h == n + 1

h = log(n+1) (以二为底)

(5)节点数为n的完全二叉树,从上到下,从左到右,除了根节点以外,都满足 i/2 、 i 、 2*i 、 2*i + 1规则

四、顺序/链式存储🤯🤯🤯

4.1 顺序存储

性质5,我们可以将任意一颗二插树构造成完全二叉树/满二叉树,找到父节点、子节点

4.2 链式存储

(1)深度搜索过程

前序遍历(根左右):只保留第一次访问

中序遍历(左根右):只保留第二次访问

后序遍历(左右根):只保留最后一次访问

(2)广度搜索过程

获取新节点->处理新节点->有左节点入左,有右节点入右

(3)根据遍历结果重构二叉树题目

如何解:前序+中序、后序+中序

前序第一个节点是根节点,中序里,在根节点左边元素全在左子树中

在根节点右边元素全在右子树中

后序最后一个节点是根节点,中序里,根节点往左,都是左子树的节点

根节点往右,都是右子树的节点

都是先找根节点

前序从开头找(从前往后),后序从尾巴找(从后往前)

找到根节点后去中序里找属于左右子树中的节点,分区

再继续找下一个根节点

记住根节点都是从前后序里找、找到根节点后分区,再继续找下一个根节点

根节点左边元素全安排好了?那前/后序继续出现的第一个节点又是右边子树的根节点

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

相关推荐
papership6 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826526 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa6 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!6 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
丑八怪大丑7 小时前
Java数据结构与集合源码
数据结构
一个爱编程的人15 小时前
一个数是不是素数
数据结构·算法
忡黑梨15 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云16 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手16 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
牢姐与蒯16 小时前
cpp数据结构之map
数据结构