【数据结构】二叉树

完全二叉树

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

所以这种情况也是:

几条性质

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

推导:一棵树的所有结点个数为n~0~+n~1~+n2 ---> 这棵树的边有n~0~+n~1~+n~2~ -1 条

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

那么n~0~+n~1~+n~2~ -1 = n~1~+2 *n~2~

可得 n~0~ = n~2~ + 1

证毕。

  1. 度数之和等于边数的二倍(握手定理)
  2. 树中结点与边的关系为结点数-边数=1
  3. 高度为h的二叉树至多有2^h^-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

相关推荐
pianmian11 小时前
python数据结构基础(7)
数据结构·算法
ChoSeitaku4 小时前
链表交集相关算法题|AB链表公共元素生成链表C|AB链表交集存放于A|连续子序列|相交链表求交点位置(C)
数据结构·考研·链表
偷心编程4 小时前
双向链表专题
数据结构
香菜大丸4 小时前
链表的归并排序
数据结构·算法·链表
jrrz08284 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
@小博的博客4 小时前
C++初阶学习第十弹——深入讲解vector的迭代器失效
数据结构·c++·学习
泉崎6 小时前
11.7比赛总结
数据结构·算法
你好helloworld6 小时前
滑动窗口最大值
数据结构·算法·leetcode
JSU_曾是此间年少7 小时前
数据结构——线性表与链表
数据结构·c++·算法
sjsjs118 小时前
【数据结构-合法括号字符串】【hard】【拼多多面试题】力扣32. 最长有效括号
数据结构·leetcode