【数据结构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)根据遍历结果重构二叉树题目

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

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

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

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

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

都是先找根节点

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

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

再继续找下一个根节点

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

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

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

相关推荐
逆境不可逃2 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表
wefg13 小时前
【算法】倍增思想(快速幂)
数据结构·c++·算法
Zik----3 小时前
Leetcode24 —— 两两交换链表中的节点(迭代法)
数据结构·算法·链表
!停3 小时前
数据结构二叉树—链式结构(下)
数据结构·算法
666HZ6664 小时前
数据结构5.0 树与二叉树
数据结构
Zik----5 小时前
Leetcode27 —— 移除元素(双指针)
数据结构·算法
睡一觉就好了。6 小时前
list容器简介及其接口函数
数据结构·list
adore.9686 小时前
2.22 oj基础92 93 94+U12
数据结构·c++·算法
Rhystt6 小时前
代码随想录第二十六天|669. 修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树
数据结构·c++·算法·leetcode