树的先序遍历的栈实现
Posted 范仁义
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了树的先序遍历的栈实现相关的知识,希望对你有一定的参考价值。
树的先序遍历的栈实现
先把根节点访问了,右子树入栈,去访问左子树。
1 void preorder(tree bt) //先序遍历bt所指的二叉树 2 { 3 tree stack[n]; //栈 4 int top = 0; //栈顶指针 5 tree P; 6 while(bt || top) 7 { 8 while(bt) //非叶结点 9 { 10 cout << bt->data; //访问根 11 stack[++top] = bt->rchild; //右子树压栈 12 bt = bt->lchild; //遍历左子树 13 } 14 if(top) //栈中所有元素出栈,遍历完毕 15 { 16 bt = stack[top--]; 17 } 18 } 19 }
以上是关于树的先序遍历的栈实现的主要内容,如果未能解决你的问题,请参考以下文章