二叉树的相关算法操作.docx

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
二叉树的相关算法操作

二叉链表的存储结构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;??}??按先序次序输入二叉树的结点值,0表示空树。二叉树的遍历(先序、中序、后序)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);????????????

文档评论(0)

jiupshaieuk12 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:6212135231000003

1亿VIP精品文档

相关文档