【数据结构】二叉树

完全二叉树

是指所有结点度数小于等于2的树

所以这种情况也是:

几条性质

  1. 一个具有n个结点的完全二叉树的深度为: log ⁡ 2 ( n + 1 ) 的结果向上取整。 \\\log_{2}(n+1) \ \ 的结果向上取整。 log2(n+1) 的结果向上取整。
  2. 设度为0的结点个数是n0,度为1的结点个数是n1,度为2的结点个数是n2,那么n0 = n2 + 1。

推导:一棵树的所有结点个数为n0+n1+n2 ---> 这棵树的边有n0+n1+n2 -1 条

这棵树的边数同时也等于n1+2*n2(度为0的能提供0条边,1的提供1条边,2的提供2条边)

那么n0+n1+n2 -1 = n1+2 *n2

可得 n0 = n2 + 1

证毕。

  1. 度数之和等于边数的二倍(握手定理)
  2. 树中结点与边的关系为结点数-边数=1
  3. 高度为h的二叉树至多有2h-1个结点(满二叉树)

利用等比数列求和公式算得:

将各层结点个数加起来即可。

遍历方式

以这棵树为例:

前序

所有子树按照 根左右的方式进行遍历

A B D NULL NULL E NULL NULL C F NULL NULL NULL

中序

所有子树按照 左根右 的方式进行遍历

NULL D NULL B NULL E NULL A NULL F NULL C NULL

后序

所有子树按照 左右根 的方式进行遍历

NULL NULL D NULL NULL E B NULL NULL F NULL C A

层序

所有子树按照 从上到下 从左到右 的方式进行遍历

ABCDEF

相关推荐
散11233 分钟前
01数据结构-交换排序
数据结构·算法
浮灯Foden5 小时前
算法-每日一题(DAY13)两数之和
开发语言·数据结构·c++·算法·leetcode·面试·散列表
山顶风景独好9 小时前
【Leetcode】随笔
数据结构·算法·leetcode
科大饭桶10 小时前
C++入门自学Day11-- String, Vector, List 复习
c语言·开发语言·数据结构·c++·容器
Cx330❀12 小时前
【数据结构初阶】--排序(四):归并排序
c语言·开发语言·数据结构·算法·排序算法
艾莉丝努力练剑12 小时前
【C语言16天强化训练】从基础入门到进阶:Day 1
c语言·开发语言·数据结构·学习
番薯大佬13 小时前
编程算法实例-冒泡排序
数据结构·算法·排序算法
ankleless13 小时前
数据结构(03)——线性表(顺序存储和链式存储)
数据结构·考研·链表·顺序表·线性表
KarrySmile13 小时前
Day8--滑动窗口与双指针--1004. 最大连续1的个数 III,1658. 将 x 减到 0 的最小操作数,3641. 最长半重复子数组
数据结构·算法·双指针·滑动窗口·不定长滑动窗口·最大连续1的个数·最长子数组
大阳1231 天前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验