分类: 数据结构及算法2012-04-28 14:30 8572人阅读 评论(6) 收藏 举报

利用栈实现二叉树的先序,中序,后序遍历的非递归操作

  1. #include <stdio.h>
  2. #include <malloc.h>
  3. #include <stdlib.h>
  4. #include <queue>
  5. #include <stack>
  6. #include <iostream>
  7. using namespace std;
  8. typedef struct BiTNode{
  9. char data;
  10. BiTNode *lchild, *rchild;
  11. }BiTNode,*BiTree;
  12. void CreateBiTree(BiTree &T)//建树,按先序顺序输入节点
  13. {
  14. char ch;
  15. scanf("%c",&ch);
  16. if(ch==' ')
  17. {
  18. T=NULL;
  19. return;
  20. }
  21. else
  22. {
  23. T=(BiTree)malloc(sizeof(BiTNode));
  24. if(!T)
  25. exit(1);
  26. T->data=ch;
  27. CreateBiTree(T->lchild);
  28. CreateBiTree(T->rchild);
  29. }
  30. }
  31. void InOrderTraverse(BiTree T)//非递归中序遍历
  32. {
  33. stack<BiTree> Stack;
  34. if(!T)
  35. {
  36. printf("空树!\n");
  37. return;
  38. }
  39. while(T || !Stack.empty())
  40. {
  41. while(T)
  42. {
  43. Stack.push(T);
  44. T=T->lchild;
  45. }
  46. T=Stack.top();
  47. Stack.pop();
  48. printf("%c",T->data);
  49. T=T->rchild;
  50. }
  51. }
  52. void PreOrderTraverse(BiTree T)//非递归先序遍历
  53. {
  54. stack<BiTree> Stack;
  55. if(!T)
  56. {
  57. printf("空树!\n");
  58. return;
  59. }
  60. while(T || !Stack.empty())
  61. {
  62. while(T)
  63. {
  64. Stack.push(T);
  65. printf("%c",T->data);
  66. T=T->lchild;
  67. }
  68. T=Stack.top();
  69. Stack.pop();
  70. T=T->rchild;
  71. }
  72. }
  73. void PostOrderTraverse(BiTree T)//非递归后序遍历,用一个标记标记右子树是否访问过
  74. {
  75. int flag[20];
  76. stack<BiTree> Stack;
  77. if(!T)
  78. {
  79. printf("空树!\n");
  80. return;
  81. }
  82. while(T)
  83. {
  84. Stack.push(T);
  85. flag[Stack.size()]=0;
  86. T=T->lchild;
  87. }
  88. while(!Stack.empty())
  89. {
  90. T=Stack.top();
  91. while(T->rchild && flag[Stack.size()]==0)
  92. {
  93. flag[Stack.size()]=1;
  94. T=T->rchild;
  95. while(T)
  96. {
  97. Stack.push(T);
  98. flag[Stack.size()]=0;
  99. T=T->lchild;
  100. }
  101. }
  102. T=Stack.top();
  103. printf("%c",T->data);
  104. Stack.pop();
  105. }
  106. }
  107. void main()
  108. {
  109. BiTree T;
  110. CreateBiTree(T);
  111. PreOrderTraverse(T);
  112. printf("\n");
  113. InOrderTraverse(T);
  114. printf("\n");
  115. PostOrderTraverse(T);
  116. printf("\n");
  117. }
 

ZT 二叉树先序,中序,后序遍历非递归实现的更多相关文章

  1. 分别求二叉树前、中、后序的第k个节点

    一.求二叉树的前序遍历中的第k个节点 //求先序遍历中的第k个节点的值 ; elemType preNode(BTNode *root,int k){ if(root==NULL) return ' ...

  2. 【算法】二叉树、N叉树先序、中序、后序、BFS、DFS遍历的递归和迭代实现记录(Java版)

    本文总结了刷LeetCode过程中,有关树的遍历的相关代码实现,包括了二叉树.N叉树先序.中序.后序.BFS.DFS遍历的递归和迭代实现.这也是解决树的遍历问题的固定套路. 一.二叉树的先序.中序.后 ...

  3. 前、中、后序遍历随意两种是否能确定一个二叉树?理由? && 栈和队列的特点和区别

    前序和后序不能确定二叉树理由:前序和后序在本质上都是将父节点与子结点进行分离,但并没有指明左子树和右子树的能力,因此得到这两个序列只能明确父子关系,而不能确定一个二叉树. 由二叉树的中序和前序遍历序列 ...

  4. DS Tree 已知先序、中序 => 建树 => 求后序

    参考:二叉树--前序和中序得到后序 思路历程: 在最初敲的时候,经常会弄混preorder和midorder的元素位置.大体的思路就是在preorder中找到根节点(根节点在序列的左边),然后在mid ...

  5. TZOJ 3209 后序遍历(已知中序前序求后序)

    描述 在数据结构中,遍历是二叉树最重要的操作之一.所谓遍历(Traversal)是指沿着某条搜索路线,依次对树中每个结点均做一次且仅做一次访问. 这里给出三种遍历算法. 1.中序遍历的递归算法定义:  ...

  6. [Java]算术表达式求值之二(中序表达式转后序表达式方案,支持小数)

    Inlet类,入口类,这个类的主要用途是验证用户输入的算术表达式: package com.hy; import java.io.BufferedReader; import java.io.IOEx ...

  7. [Java]算术表达式求值之一(中序表达式转后序表达式方案)

    第二版请见:https://www.cnblogs.com/xiandedanteng/p/11451359.html 入口类,这个类的主要用途是粗筛用户输入的算术表达式: package com.h ...

  8. 已知树的前序、中序,求后序的java实现&已知树的后序、中序,求前序的java实现

    public class Order { int findPosInInOrder(String str,String in,int position){ char c = str.charAt(po ...

  9. 二叉树前中后/层次遍历的递归与非递归形式(c++)

    /* 二叉树前中后/层次遍历的递归与非递归形式 */ //*************** void preOrder1(BinaryTreeNode* pRoot) { if(pRoot==NULL) ...

随机推荐

  1. iOS 微信支付SDK与微信友盟分享两者同时集成时,出现的问题与解决之路。

    这两天改版一个旧的APP,要旧貌换新颜,拿到app后进行编译,一直报下面的错误. 报不认识的符号名PayReq错误.奇怪,啥也没动就这样,真不知道给的包是不是本来就是个报错的工程. 不管怎样,要对它修 ...

  2. 遇见CUBA CLI

    原文:Meet CLI for CUBA Platform 翻译:CUBA China CUBA-Platform 官网 : https://www.cuba-platform.com CUBA Ch ...

  3. JavaScript窗口打开与关闭及如何使用opener使子窗口对父窗口进行操作

    一.打开与关闭窗口 1.打开窗口:可以使用window对象中的Open()方法. newWindow = window.open(url,windowname,location); 参数说明: url ...

  4. Keepalived 无法自动转换主备角色,请关注 iptables 防火墙配置

    最近在研究服务器高可用集群 (HA)…… 搭建了主备两台Keepalived,配置什么的全是网上照抄的,被验证过无数遍的示例…… 然而Master和Backup无法自动切换.两边会同时绑定浮动IP(V ...

  5. 4.1 SQL的本质

    对于早期的关系数据库,整个行业做了很多努力,试图统一不同的专用查询语言.IBM曾建立了一个早期的标准,被称为Structured English Query Language,这个名字缩写为SEQUE ...

  6. Day7:掌握APICloud应用管理相关服务的配置使用和相关API,包括:应用发布、版本管理、云修复、闪屏广告等。理解APICloud APP优化策略和编码规范;了解APICloud多Widget管理机制和SuperWebview的使用

    主要内容: 1. 应用发布 1.1 云编译 1.2 全包加密 网页全包加密:对网页中全包的html,css,javascript代码进行加密,加密后的网友代码都是不可读的,并且不能通过常用的格式化工具 ...

  7. Java - 延迟初始化

    延迟初始化(lazy initialization),也就是在真正被使用的时候才开始初始化的技巧. 不论是静态还是实例,都可以进行延迟初始化. 其本质是初始化开销和访问开销之间的权衡. 毕竟是一种优化 ...

  8. MySQL3:存储过程和函数

    什么是存储过程 简单说,存储过程就是一条或多条SQL语句的集合,可视为批文件,但是起作用不仅限于批处理.本文主要讲解如何创建存储过程和存储函数以及变量的使用,如何调用.查看.修改.删除存储过程和存储函 ...

  9. spring boot入门笔记 (二) - application.properties配置文件

    项目最重要的一个东西,用来定义整个项目的一些东西(端口.访问项目的名称.数据源.日志.集成mybatis等框架.静态资源目录.thymeleaf.热部署等),很重要很重要的. #整个项目的端口号,默认 ...

  10. 微信小程序之雪碧图(css script)

    今天有朋友问我关于微信小程序中如何在不占用大量网络带宽的情况下快速加载图片,我给他推荐了两种方式 1.雪碧图(css script),有过前端经验的朋友应该都有接触过. 2.懒加载. 由于时间关系我就 ...