全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C 语言二叉树几种遍历方法详解及实例

二叉树的一些概念

二叉树就是每个结点最多有两个子树的树形存储结构。先上图,方便后面分析。


 1 满二叉树和完全二叉树 

上图就是典型的二叉树,其中左边的图还叫做满二叉树,右边是完全二叉树。然后我们可以得出结论,满二叉树一定是完全二叉树,但是反过来就不一定。满二叉树的定义是除了叶子结点,其它结点左右孩子都有,深度为k的满二叉树,结点数就是2的k次方减1。完全二叉树是每个结点都与深度为k的满二叉树中编号从1到n一一对应。

 2 树的深度

树的最大层次就是深度,比如上图,深度是4。很容易得出,深度为k的树,拥有的最大结点数是2的k次方减1。

 3 树的孩子,兄弟,双亲

上图中,B,C是A的孩子,B,C之间互为兄弟,A是B,C的双亲。

 二如何创建二叉树

先说说二叉树的存储结构,跟很多其它模型一样,也有顺序和链式两种方式。前者虽然使用简单,但是存在浪费空间的问题,举个例子,下图的二叉树,用顺序的方式存储(0表示空,没有子树)是:

1 2 3 4 5 6 7 0 0 0 0 8 0 0 0


 是不是相当浪费空间呢。

 链式结构可以定义如下:

typedef struct _BiTNode 
{ 
  int data; 
  _BiTNode *leftChild; 
  _BiTNode *rightChild; 
}BiTNode, *pBiTree; 

然后就可以写一个函数来创建二叉树,过程是在控制台输入a表示退出当前这一层,不再为该层创建左右孩子。输入其它字母表示继续创建。比如下面的输入序列:


 创建了如下结构的二叉树,


 每个结点里的数值是随机生成的小于100的数字。同时我也写了一个自动的命令序列函数,方便测试,不用手动输入,非自动和自动创建的函数如下:

//创建二叉树, 先序顺序 
int CreateBiTree(pBiTree *root) 
{ 
  char ch = 0; 
  fflush(stdin); 
  if ((ch = getchar()) == 'a')//控制树的结构 
  { 
    *root = NULL; 
  } 
  else 
  { 
    *root = (BiTNode *)malloc(sizeof(BiTNode)); 
    if (!(*root)) 
    { 
      return RET_ERROR; 
    } 
    (*root)->data = GetRandom(); 
    CreateBiTree(&(*root)->leftChild); 
    CreateBiTree(&(*root)->rightChild); 
  } 
  return RET_OK; 
} 
 
int g_i = 0; 
//创建二叉树,自动执行,方便测试 
int CreateBiTreeAuto(pBiTree *root) 
{ 
  char szOrder[] = "bbaabaa"; 
  char ch = 0; 
  if (szOrder[g_i++] == 'a')//控制树的结构 
  { 
    *root = NULL; 
  } 
  else 
  { 
    *root = (BiTNode *)malloc(sizeof(BiTNode)); 
    if (!(*root)) 
    { 
      return RET_ERROR; 
    } 
    (*root)->data = GetRandom(); 
    CreateBiTreeAuto(&(*root)->leftChild); 
    CreateBiTreeAuto(&(*root)->rightChild); 
  } 
  return RET_OK; 
} 

三遍历顺序

先序遍历

先序遍历是先访问根结点,再左子树,再右子树,比如图1中的右图,先序遍历的输出如下:

A,B,D,H,I,E,J,K,C,F,G

根据上面的思想,很容易用递归的形式写出先序遍历的代码:

//先序遍历 
int PreOrderVisitTree(pBiTree T, VisitType pFuncVisit) 
{ 
  if (T) 
  { 
    (*pFuncVisit)(T->data); 
    if (PreOrderVisitTree(T->leftChild, pFuncVisit) == RET_OK) 
    { 
      if (PreOrderVisitTree(T->rightChild, pFuncVisit) == RET_OK) 
      { 
        return RET_OK; 
      } 
    } 
    return RET_ERROR; 
  } 
  else 
  { 
    return RET_OK; 
  } 
} 

中序遍历和后序遍历

有了先序的经验,这两个就很好理解了,中序是先访问左子树, 再根结点,再右子树, 后序是先访问左子树, 再右子树,再根结点。代码更容易,只要改一下调用顺序就可以了。

不过我这里给出一种非递归的实现。递归固然是清晰明了,但是存在效率低的问题,非递归的方案用栈结构来存结点信息,通过出栈访问来遍历二叉树。它思想是这样的,当栈顶中的指针非空时,遍历左子树,也就是左子树根的指针进栈。当栈顶指针为空时,应退至上一层,如果是从左子树返回的,访问当前层,也就是栈顶中的根指针结点。如果是从右子树返回,说明当前层遍历完毕,继续退栈。代码如下:

//中序遍历, 非递归实现 
int InOrderVisitTree(pBiTree T, VisitType pFuncVisit) 
{ 
  ponyStack binaryTreeStack; 
  InitStack(&binaryTreeStack, 4); 
  Push(&binaryTreeStack, &T); 
  pBiTree pTempNode; 
 
  while (!IsEmptyStack(binaryTreeStack)) 
  { 
    while((GetTop(binaryTreeStack, &pTempNode) == RET_OK) && (pTempNode != NULL)) 
    { 
      Push(&binaryTreeStack, &(pTempNode->leftChild)); 
    } 
    Pop(&binaryTreeStack, &pTempNode); 
    if (!IsEmptyStack(binaryTreeStack)) 
    { 
      Pop(&binaryTreeStack, &pTempNode); 
      (*pFuncVisit)(pTempNode->data); 
      Push(&binaryTreeStack, &(pTempNode->rightChild)); 
    } 
  } 
  return RET_OK; 
} 

代码下载地址:http://xiazai./201701/yuanma/BinaryTreeDemo-master().rar

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 二叉树几种遍历方法  # 二叉树几种遍历  # 二叉树遍历总结  # PHP实现的线索二叉树及二叉树遍历方法详解  # PHP实现二叉树的深度优先与广度优先遍历方法  # C++实现二叉树非递归遍历方法实例总结  # C++二叉树结构的建立与基本操作  # c++二叉树的几种遍历算法  # 二叉树先序遍历的非递归算法具体实现  # python二叉树遍历的实现方法  # JS中的二叉树遍历详解  # c语言版本二叉树基本操作示例(先序 递归 非递归)  # 子树  # 遍历  # 二叉树  # 递归  # 链式  # 上图  # 是从  # 很容易  # 就可以  # 我也  # 这一  # 是在  # 都有  # 也有  # 很好  # 最多  # 下载地址  # 是这样  # 两种  # 我们可以 


相关文章: ,sp开头的版面叫什么?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  常州企业网站制作公司,全国继续教育网怎么登录?  建站VPS配置与SEO优化指南:关键词排名提升策略  建站主机与服务器功能差异如何区分?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  建站VPS选购需注意哪些关键参数?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  建站之星与建站宝盒如何选择最佳方案?  如何设置并定期更换建站之星安全管理员密码?  建站10G流量真的够用吗?如何应对访问高峰?  php json中文编码为null的解决办法  网站制作的步骤包括,正确网址格式怎么写?  简单实现Android文件上传  制作网站公司那家好,网络公司是做什么的?  如何制作算命网站,怎么注册算命网站?  已有域名如何快速搭建专属网站?  如何通过cPanel快速搭建网站?  *服务器网站为何频现安全漏洞?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  建站之星Pro快速搭建教程:模板选择与功能配置指南  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  建站之星后台密码如何安全设置与找回?  c# await 一个已经完成的Task会发生什么  建站之星导航配置指南:自助建站与SEO优化全解析  黑客如何通过漏洞一步步攻陷网站服务器?  如何在万网自助建站平台快速创建网站?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  5种Android数据存储方式汇总  建站OpenVZ教程与优化策略:配置指南与性能提升  如何在阿里云通过域名搭建网站?  如何在万网主机上快速搭建网站?  如何零基础开发自助建站系统?完整教程解析  建站之星微信建站一键生成小程序+多端营销系统  焦点电影公司作品,电影焦点结局是什么?  如何安全更换建站之星模板并保留数据?  如何通过西部数码建站助手快速创建专业网站?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  建站之星云端配置指南:模板选择与SEO优化一键生成  如何在香港服务器上快速搭建免备案网站?  移民网站制作流程,怎么看加拿大移民官网?  建站主机是什么?如何选择适合的建站主机?  如何通过虚拟机搭建网站?详细步骤解析  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。