树的先序遍历的栈实现
先把根节点访问了,右子树入栈,去访问左子树。
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 }