二叉树是一种树的度不大于2的树,也就是它的节点的度都是小于等于2的。二叉树的子树有左右之分,左右的次序不能颠倒,因此二叉树是一个有序树。任意的二叉树都由空树、只有根节点、只有左子树、只有右子树、左右子树均存在这几种情况复合而成。
完全二叉树:完全二叉树是一种效率很高的数据结构,如果一个二叉树的深度为k,节点总数不小于2k-1,同时不大于2k-1,并且在最后一层时,每个节点从左到右保持连续,则它就是完全二叉树。
满二叉树:每一层的节点数都达到了最大值即为满二叉树。如果说一个二叉树的深度为k,且节点总数是2k-1,那它就是一个满二叉树,我们可以通过这个公式来判断一个二叉树是不是满二叉树。本质上来说,满二叉树是一种特殊的完全二叉树。
需要注意的是,虽然满二叉树是一种特殊的完全二叉树,但是完全二叉树是由满二叉树引出来的。
二叉树一般可以使用两种结构存储,一种顺序结构,一种链式结构。
typedef int HPDataType;
//顺序存储
typedef struct Heap
{HPDataType* a;//指向数组int size;//有几个值int capacity;//容量
}Heap;typedef int BTDataType;
//二叉链
struct BinaryTreeNode
{struct BinTreeNode* pleft;//指向当前节点左孩子struct BinTreeNode* pright;//指向当前节点右孩子BTDataType data;//当前节点值
}//三叉链
struct BinaryTreeNode
{struct BinTreeNode* pparent;//指向当前节点的双亲struct BinTreeNode* pleft;//指向当前节点左孩子struct BinTreeNode* pright;//指向当前节点右孩子BTDataType data;//当前节点值