递归先序遍历和中序遍历

先序:

void  preorder(bnode  *t){if(t!=NULL){ visit(t);preorder(t->lchild);  preorder(t->rchlid);}
}

中序:

void  inorder(bnode  *t){if(t!=NULL){inorder(t->lchild);visit(t);inorder(t->rchlid);}}

后序:

void  postorder (bnode  *t){if(t!=NULL){postorder (t->lchild);postorder (t->rchlid); visit(t);   }}

打印二叉树的结点以及先序遍历的顺序数

 void    printnode( bnode *T, int &k ) { //设调用时k对应的实参初始化为0if ( T != NULL ) {k++;cout<<‘(’T->data<<‘,’<<k<<“),  ”;printnode( T -> lchild, k );printnode( T -> rchild, k );}

递归算法求结点数 2、设计算法求二叉树的结点数:

分析:
(1)设置一个全局变量,在遍历二叉树的过程中,对访问的结点累计计数。
(2) 设函数void num( bnode *T )表示对以T为根的二叉树遍历和计数,分析如下:
如果T == NULL ——结点数为0,不必累计;
否则 结点数 = 左子树结点数 + 右子树结点数+1。

  void    num( bnode *T ) {           //设k是全局变量,初始化k=0if ( T != NULL ) {k++;num( T -> lchild );num( T -> rchild );}}

可以设计为int型函数形式:

  int    num( bnode * T ) {if ( T == NULL ) return(0);else  return  num( T -> lchild ) + num( T -> rchild ) + 1;}

递归构造二叉树

void create ( bitre  *&T ){cin >> x;if ( x == ’.’ ) T = NULL;else{T = new bnode;T -> data = x;create ( T -> lchild );create ( T -> rchild );}
}

非递归的先序/中序/后续算法

先序:
用一个一维数组stack[maxnode]用以实现栈,变量top表示栈顶的位置

int bitTree::PreOrder(bitTree bt){//预先定义bitTree这一个结点类作为新数据类型
bitTree stack[maxnode],p;
int top;
if(bt==nullptr)return 1;//空树时
else{p=bt;//p首先为根节点
top=-1;//栈顶
while(!(p==NULL&&top==-1))
{if(p!= NULL){visit(p->data);//访问p
top++;//栈顶加一
stack[top]=p;//先访问结点,然后入栈,然后指向右孩子
p=p->lchild;
}
else{p=stack[top];
top--;
p=p->rchild;//指向右孩子
}}

注意:中序遍历则把visit(p->data);移到p=stack[top]和
p=p->rchild;之间。
后序遍历的非递归:与先序 中序不同,后序遍历过程中,结点第一次出栈后,还要再次入栈,即结点要入两次栈,出两次栈,而访问结点是在第二次出栈时访问。因此为了区别同一个结点指针的两次出栈,设置一个标志flag:flag为1表示第一次出栈,为2表示第二次出栈,此时可以访问。可以将栈中元素数据类型定义为有指针域和标志flag域的结构体,如:
struct stacttype{
btTree link;
int flag;}

int bitTree::PostOrder(bitTree bt){//预先定义bitTree这一个结点类作为新数据类型
bitTree stack[maxnode],p;
int top,sign;
if(bt==nullptr)return 1;//空树时p=bt;//p首先为根节点
top=-1;//栈顶
while(!(p==NULL&&top==-1))
{if(p!=null){//结点第一次进栈
top++;
stack[top].link=p;
stack[top].flag=1;
p=p->lchild;//找结点的左孩子
else
{p=stack[top].link;
sign=stack[top].flag;
top--;if(sign==1)//结点第二次进栈
{top++;
stack[top].link=p;
stack[top].flag=2;
p=p->rchild;
}
else{visit(p->data);
p=null;//注意这一步,p指向空}
}
return 1;//遍历结束
}

【笔记】二叉树递归算法和非递归算法的实现 先序/中序/后续遍历 打印结点以及顺序数 构造二叉树相关推荐

  1. 遍历二叉树的递归算法与非递归算法

    遍历二叉树的递归算法与非递归算法 先来看下面这棵二叉树.如图1.现在我们要对它进行先序遍历.递归思想:就是把这个大树拆分成N棵小树,每棵小树都进行一次先序遍历.再把这些遍历连合起来就是这棵树的先序遍历 ...

  2. 递归算法转换为非递归算法的技巧

    递归算法转换为非递归算法的技巧 递归函数具有很好的可读性和可维护性,但是大部分情况下程序效率不如非递归函数,所以在程序设计中一般喜欢先用递归解决问题,在保证方法正确的前提下再转换为非递归函数以提高效率 ...

  3. zz 递归算法转换为非递归算法

    from:http://blog.csdn.net/Shunrei/archive/2010/06/19/5680579.aspx 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解 ...

  4. 递归算法到非递归算法的转换

    递归实质在定义自身的同时又出现了对自身的调用.递归算法是许多软件编程人员常用的方法,结构简单.清晰.可读性好.但在实际应用中也存在一些问题:1.并不是每一门语言都支持递归,比较典型的FORTRAN语言 ...

  5. 递归算法向非递归算法转换

    递归算法向非递归算法转换 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于某些复杂问题(例如hanio塔问题),递归算法是一种自然且合乎逻辑的解决问题的方式,但是递归算法的执 ...

  6. 递归算法与非递归算法的转化

    递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于某  些复杂问题(例如 hanio塔问题),递归算法是一种自然且合乎逻辑的解决问题的方式,  但是递归算法的执行效率通常比较差 ...

  7. 递归算法转换为非递归算法

    转 自 : https://blog.csdn.net/fbz123456/article/details/50959412 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于 ...

  8. 递归算法与非递归算法比较

    转载自:https://blog.csdn.net/mhsszm/article/details/78445591 非递归效率高:递归代码写出来思路清晰,可读性强. 生成可执行文件大小应该和编译器有关 ...

  9. 【IT笔试面试题整理】给定二叉树先序中序,建立二叉树的递归算法

    [试题描述]:  给定二叉树先序中序,建立二叉树的递归算法 其先序序列的第一个元素为根节点,接下来即为其左子树先序遍历序列,紧跟着是右子树先序遍历序列,固根节点已可从先序序列中分离.在中序序列中找到 ...

最新文章

  1. idea 搭建spring boot 项目
  2. Apache服务器部署(1)
  3. virsh 常用操作
  4. Spring component-scan类扫描加载过程
  5. 关于《资产负债表》中未分配利润项目的填列
  6. Java Web之文件的上传及下载
  7. 【效率】来了!Github 终于上线收藏夹了
  8. SQLite 入门教程(三)好多约束 Constraints
  9. C4C权限控制的一些特色功能和测试
  10. c++11 继承构造
  11. Spring @Value批注
  12. Ubuntu 14.04 为 root 帐号开启 SSH 登录
  13. 如何将asp.net MVC2项目升级为MVC3项目(微软官方自动升级工具:ASP.NET MVC 3 Application Upgrader )...
  14. 深度学习2.0-42.Auto-Encoders-无监督学习
  15. Blockly-图形化编程工具
  16. matlab 卷积神经网络 图像去噪 对抗样本修复
  17. 查看JDK版本和安装路径
  18. 六级通关笔记--词汇1
  19. 网站建设|网站导航设计超强方法总结
  20. C++获取鼠标坐标并移动鼠标

热门文章

  1. mac笔记本怎么外接显示屏_苹果MAC笔记本怎么外接显示器?
  2. 长方形与圆最近连线LISP_编写一个AutoLISP程序,画出一个边长为A的正方形,以及该正方形的内切圆,正方形的底边与正X轴的夹角为ANG...
  3. linux go redis,go-redis 连接池
  4. android 简单的音乐播放器
  5. 六十八、完成Vue项目推荐和周末游组件,并使用Ajax发起ajax请求
  6. 四、CSS知识总结(下篇)
  7. T5 PEGASUS:开源一个中文生成式预训练模型
  8. 直播报名 | 小身材大能量!用英伟达智能小车Jetbot玩转深度学习
  9. 最后9个名额丨知识图谱理论与实战(线下集训)
  10. NeurIPS 2018 | 腾讯AI Lab:可自适应于不同环境和任务的强化学习方法