关于二叉树的非递归遍历的算法疑惑

原创 2014年07月20日 16:32:24

        二叉树的遍历让递归算法的思想得到了无限的魅力施展,可以说二叉树的操作由于递归而变得简单和易于操作,只要搞清楚递归的本质和代码原理即可

但是要想脱离递归而遍历二叉树的所有元素,真的有点困难。

网上最多的一个算法是应用栈的入栈和出栈。

       我看了一些帖子,有点看不懂,自己尝试用流程框架来打印出所有元素,但都失败了,要么只能打印特定的二叉树,要么是重复打印,所以在想是不是除了栈,没有其他的方法了

附上我的代码:

期待高手指点迷津:

//中序遍历--左中右打印
int print_middle(pnode_t proot)
{
if(proot == NULL)
{
printf("print wrong\n");
return;
}
pnode_t father = NULL;
pnode_t tmp = NULL;
tmp = father;
while(proot != NULL)
{
//printf("here2\n");
father = proot;
if((father->data == 9)&&( father->left == NULL)&&(father->right == NULL))
{
break;
}
while(father != NULL)
{
//printf("here2\n");
//printf("data=%d\n",proot->data);
//break;
//father = proot;
while( father != NULL )
{
tmp = father;
father = father->left;
}
father = tmp;
printf("%d ",father->data);
if(father->right != NULL)
{
father = father->right;
}
tmp = father;
//printf("%d\n",father->data);
//break;
//printf("here\n");
if((father->left == NULL)&&(father->right == NULL))
{
//printf("here2\n");
pnode_t new = NULL;
new = find_lr_node(proot,father->data);
//printf("new=%d\n",new->data);
//printf("father=%d\n",father->data);
if(new->left != NULL)
{
if(new->left->data == father->data)
{

printf("%d ",new->data);
   new->left = NULL;
father = NULL;

pnode_t p = NULL;
p = find_lr_node(proot,new->data);
//printf("p=%d\n",p->data);
if(p->left != NULL)
{
if(p->left->data == new->data)
p->left = NULL;
new = NULL;
}
else if(p->right != NULL)
{
//printf("here3\n");
if(p->right->data == new->data)
//free(p->right);
p->right = NULL;
new = NULL;
}
//free(p->right);
//printf("p=%d\n",p->data);
//break;
}
}

else if(new->right != NULL)


{
if(new->right->data == father->data)
{
printf("%d ",new->data);
new->right = NULL;
father = NULL;
pnode_t pp = NULL;
pp = find_lr_node(proot,new->data);
if(pp->left != NULL)
{
if(pp->left->data == new->data)
pp->left = NULL;
   new = NULL;
}
if(pp->right != NULL)
{
if(pp->right->data == new->data)
pp->right = NULL;
new = NULL;
}
}
}
//printf("here5\n");
//printf("here\n");
//break;

}
//printf("here6\n");

}
}
    printf("\n");

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

史上最简明易懂非递归遍历二叉树算法

三种不同的遍历方式区别在于栈空间的释放时机和输出结点信息时机的不同:先序和中序遍历是在访问栈顶元素的右孩子(右子树)之前退栈,而后序遍历在访问右子树之后退栈;先序遍历是在某结点入栈时输出其信息,而中序...
  • QiaoRuoZhuo
  • QiaoRuoZhuo
  • 2014年10月29日 14:59
  • 3823

对于二叉树三种非递归遍历方式的理解

利用栈实现二叉树的先序,中序,后序遍历的非递归操作 栈是一种先进后出的数据结构,其本质应是记录作用,支撑回溯(即按原路线返回);因此,基于其的二叉树遍历操作深刻的体现了其特性: 1.先入、后出,只...
  • sdulibh
  • sdulibh
  • 2016年01月24日 11:25
  • 1618

二叉树的非递归遍历及算法分析

用递归遍历的优点是算法简单明了,缺点也十分明显:对于栈的消耗比较大。尤其是在嵌入式应用中,嵌入式处理器资源往往有限。每次递归调用,都会涉及到通用寄存器、SP指针、PC指针等的压栈。当树的深度比较大时,...
  • u012914709
  • u012914709
  • 2015年03月20日 22:29
  • 696

经典算法学习——非递归遍历二叉树

我们知道二叉树是一种递归定义的数据结构,包括二叉树的创建、遍历、求树高、叶子节点个数等等。使用递归来进行以上操作非常的简便,相关实现请参考 《C语言实现二叉树的基本操作》。但是今天我们剑走偏锋,使用非...
  • CHENYUFENG1991
  • CHENYUFENG1991
  • 2016年10月03日 12:28
  • 2402

【数据结构与算法】二叉树递归与非递归遍历(附完整源码)

二叉树是一种非常重要的数据结构,很多其他数据机构都是基于二叉树的基础演变过来的。二叉树有前、中、后三种遍历方式,因为树的本身就是用递归定义的,因此采用递归的方法实现三种遍历,不仅代码简洁且容易理解,但...
  • mmc_maodun
  • mmc_maodun
  • 2013年10月24日 08:58
  • 40942

详细讲解二叉树三种遍历方式的递归与非递归实现

详细讲解二叉树三种遍历方式的递归与非递归实现 分类: 数据结构随笔2013-10-24 08:58 518人阅读 评论(14) 收藏 举报 二叉树是一种非常重要的数据结...
  • pi9nc
  • pi9nc
  • 2013年10月24日 23:44
  • 44666

二叉树几种遍历算法的非递归实现

二叉树遍历的非递归实现 相对于递归遍历二叉树,非递归遍历显得复杂了许多,但换来的好处是算法的时间效率有了提高。下面对于我学习非递归遍历二叉树算法的过程进行总结为了便于理解,这里以下图的二叉树为例,分析...
  • kelvinmao
  • kelvinmao
  • 2016年05月15日 11:43
  • 4626

二叉树的遍历详解(前序中序后序层次-递归和非递归)

二叉树二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不...
  • gatieme
  • gatieme
  • 2016年04月15日 17:04
  • 7044

二叉树的前序、中序、后序的递归与非递归遍历算法实现

看代码一目了然。 C++代码:#include #include #include using namespace std;//二叉树节点 typedef struct BitNode{ ...
  • u011954296
  • u011954296
  • 2016年07月12日 12:31
  • 2802

二叉树的四种遍历(递归、非递归)

1、递归遍历/** * 先序遍历 * @param root */ public void printFirstTree(TreeNode root){ ...
  • GYQJN
  • GYQJN
  • 2016年09月30日 11:20
  • 1051
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于二叉树的非递归遍历的算法疑惑
举报原因:
原因补充:

(最多只允许输入30个字)