二叉树的二叉链表表示与实现
2017-08-08 10:21
330 查看
二叉树的特点是每个结点至多只有两棵子树,且二叉树有左右字子树之分,次序不能任意颠倒。二叉树的存储结构可以用顺序存储和链式存储来存储。二叉树一般使用链式存储结构,由二叉树的定义可知,二叉树的结点由一个数据元素和分别指向其左右孩子的指针构成,即二叉树的链表结点中包含3个域,这种结点结构的二叉树存储结构称之为二叉链表。
创建一棵二叉树
二叉树的遍历
二叉树的深度
叶子结点数
释放二叉树
typedef struct tnode { elemtype data; struct tnode *lchild; struct tnode *rchild; }*bitree, bitnode;
创建一棵二叉树
int create_bitree(bitree *bt) { elemtype data; scanf("%d", &data); if (0 == data) { *bt = NULL; } else { *bt = (bitree)malloc(sizeof(bitnode)); if (!(*bt)) exit(OVERFLOW); (*bt)->data = data; create_bitree(&(*bt)->lchild); create_bitree(&(*bt)->rchild); } return OK; }
二叉树的遍历
//先序 void preorder(bitree bt, int (*visit)(elemtype e)) { if (bt) { visit(bt->data); preorder(bt->lchild, visit); preorder(bt->rchild, visit); } } //中序 void inorder(bitree bt, int (*visit)(elemtype e)) { if (bt) { inorder(bt->lchild, visit); visit(bt->data); inorder(bt->rchild, visit); } } //后序 void postorder(bitree bt, int (*visit)(elemtype e)) { if (bt) { postorder(bt->lchild, visit); postorder(bt->rchild, visit); visit(bt->data); } }
二叉树的深度
int get_tree_depth(bitree bt) { int ldepth, rdepth; if (!bt) return 0; else if (!bt->lchild && !bt->rchild) return 1; else { ldepth = get_tree_depth(bt->lchild); rdepth = get_tree_depth(bt->rchild); return (ldepth > rdepth ? ldepth : rdepth) + 1; } }
叶子结点数
int get_num_of_leave(bitree bt) { if (!bt) return 0; else if (!bt->lchild && !bt->rchild) return 1; else return (get_num_of_leave(bt->lchild) + get_num_of_leave(bt->rchild)); }
释放二叉树
void free_bitree(bitree *bt) { if (*bt) { if ((*bt)->lchild) free_bitree(&(*bt)->lchild); if ((*bt)->rchild) free_bitree(&(*bt)->rchild); free(*bt); *bt = NULL; } }
相关文章推荐
- 二叉树的二叉链表表示与实现
- 二叉树的二叉链表表示与实现
- 二叉树的二叉链表表示与实现
- 二叉树采用二叉链表结构表示。设计并实现如下算法:后序递归建树,先序非递归遍历该树。
- 二叉树采用二叉链表结构表示。设计并实现如下算法:输入某棵二叉树的广义表形式,建立该二叉树,并按层次遍历该二叉树。
- 二叉树的二叉链表表示与实现
- 二叉树的二叉链表表示与实现
- 数据结构之---C语言实现二叉树的二叉链表存储表示
- 二叉树的存储表示与实现
- 广义表表示二叉树结构生成二叉链表的算法
- C#实现二叉树--二叉链表结构
- 二叉树的查找、二叉树高度、二叉树获得双亲结点、构造二叉树、二叉树的广义表表示法、二叉树的插入删除、二叉树的非递归实现
- 谈遍历二叉树的方法(实例列举二叉链表实现二叉树) 推荐
- 二叉树顺序表示的实现
- 普通二叉树转二叉链表(孩子兄弟表示法)
- C++实现二叉树之二叉链表
- 二叉树的二叉链表表示
- [置顶] 二叉树的链表表示法实现
- 数据结构(严蔚敏)二叉树的二叉链表存储表示
- 普通二叉树转二叉链表(孩子兄弟表示法)