来源:网络
一、树
在谈二叉树前先谈下树和图的概念
树:不包含回路的连通无向图(树是一种简单的非线性结构)
树有着不包含回路这个特点,所以树就被赋予了很多特性
1、一棵树中任意两个结点有且仅有唯一的一条路径连通
2、一棵树如果有n个结点,那它一定恰好有n-1条边
3、在一棵树中加一条边将会构成一个回路
4、树中有且仅有一个没有前驱的结点称为根结点
在对树进行讨论的时候将树中的每个点称为结点,
根结点:没有父结点的结点
叶结点:没有子结点的结点
内部结点:一个结点既不是根结点也不是叶结点
每个结点还有深度,比如上图左边的树的4号结点深度是3(深度是指从根结点到这个结点的层数,根结点为第一层)
二、二叉树
基本概念:
二叉树是一种非线性结构,二叉树是递归定义的,其结点有左右子树之分
二叉树的存储结构:
二叉树通常采用链式存储结构,存储结点由数据域和指针域(指针域:左指针域和右指针域)组成,二叉树的链式存储结构也称为二叉链表,对满二叉树和完全二叉树可按层次进行顺序存储
特点:
1、每个结点最多有两颗子树
2、左子树和右子树是有顺序的,次序不能颠倒
3、即使某结点只有一个子树,也要区分左右子树
4、二叉树可为空,空的二叉树没有结点,非空二叉树有且仅有一个根节点
二叉树中有两种特殊的二叉树:满二叉树、完全二叉树
满二叉树:二叉树中每个内部结点都有存在左子树和右子树(或者说满二叉树所有的叶结点都有同样的深度)
<