数据结构(5.2_1)——二叉树的基本定义和术语

二叉树的基本概念

二叉树是n(n>=0)个结点的有限集合:

  1. 或者为空二叉树,即n=0;
  2. 或者由一个根结点 和两个互不相交的被称为根的左子树右子树组成。左子树和右子树又分别是一颗二叉树。

特点:每个结点至多只有两颗字数;左子树不能颠倒(二叉树是有序树)

二叉树的五种状态

几种特殊的二叉树

满二叉树 :一棵高度为h,且含有个结点的二叉树

特点:

  1. 只有最后一层有叶子结点
  2. 不存在度为1的结点
  3. 按层序从1开始编号,结点i的左孩子为2i,右孩子为2i+1;结点i的父结点为[i/2](如果有的话)

完全二叉树:当且仅当其每个结点都与高度为h的满二叉树中编号为1~n的结点一一对应时,称为完全二叉树

特点:

  1. 只有最后两层可能有叶子结点
  2. 最多只有一个度为1的结点,且该结点只有左孩子而无右孩子
  3. 按层序从1开始编号,结点i的左孩子为2i,右孩子为2i+1;结点i的父结点为[i/2](如果有的话)
  4. 为分支结点,为叶子结点

二叉排序树 :一棵二叉树或者是空二叉树,或者具有如下性质的二叉树:

左子树上所有结点的关键字均小于根结点的关键字:

右子树上所有结点的关键字均大于根结点的关键字:

左子树和右子树又各是一棵二叉排序树

二叉排序树可用于元素的排序、搜索

平衡二叉树:树上任一结点的左子树和右子树的深度之差不超过1.

平衡二叉树能有更高的搜索效率

总结

相关推荐
Swift社区19 分钟前
LeetCode 453 - 最小操作次数使数组元素相等
算法·leetcode·职场和发展
八月ouc22 分钟前
Python实战小游戏(二): 文字冒险游戏
数据结构·python·文字冒险
hoiii18725 分钟前
LR算法辅助的MIMO系统Zero Forcing检测
算法
糖葫芦君27 分钟前
Lora模型微调
人工智能·算法
EXtreme3531 分钟前
【数据结构】二叉树进阶:层序遍历不仅是按层打印,更是形态判定的利器!
c语言·数据结构·二叉树·bfs·广度优先搜索·算法思维·面试必考
小李小李快乐不已36 分钟前
二叉树理论基础
数据结构·c++·算法·leetcode
仰泳的熊猫40 分钟前
1149 Dangerous Goods Packaging
数据结构·c++·算法·pat考试
_OP_CHEN1 小时前
【算法基础篇】(三十七)图论基础之多源最短路:Floyd 算法吃透所有点对最短路径!
算法·蓝桥杯·图论·算法竞赛·floyd算法·acm/icpc·多源最短路
Web极客码1 小时前
如何选择最适合的内容管理系统(CMS)?
java·数据库·算法
程序员三明治1 小时前
【动态规划】01背包与完全背包问题详解,LeetCode零钱兑换II秒解,轻松解力扣
算法·leetcode·动态规划·java后端·01背包·完全背包·零钱兑换