试直接利用栈的基本操作写出先序遍历的非递归
形式的算法(提示:不必按3.3.2节介绍的从递归到非递归
的方法而直接写出非递归算法)。
要求实现下列函数:
void PreOrder(BiTree bt, void (*visit)(TElemType));
/* 使用栈,非递归先序遍历二叉树bt, */
/* 对每个结点的元素域data调用函数visit */
二叉链表类型定义:
typedef struct BiTNode {
TElemType data;
BiTNode *lchild,*rchild;
} BiTNode, *BiTree;
可用栈类型Stack的相关定义:
typedef BiTree SElemType; // 栈的元素类型
Status InitStack(Stack &S);
Status StackEmpty(Stack S);
Status Push(Stack &S, SElemType e);
Status Pop(Stack &S, SElemType &e);
Status GetTop(Stack S, SElemType &e);
void PreOrder(BiTree bt, void (*visit)(TElemType))
/* 使用栈,非递归先序遍历二叉树bt, */
/* 对每个结点的元素域data调用函数visit */
{
Stack s;
BiTree pt=bt;
InitStack(s);//创建辅助栈,用来保存路径信息
while(pt||!StackEmpty(s)){
if(pt){
visit(pt->data);
Push(s,pt);
pt=pt->lchild;
}else{
Pop(s,pt); //从左子树返回
if(pt->rchild){ //信息可用
pt=pt->rchild;//提取信息
}
else{ //信息不可用
Pop(s,pt);
pt=pt->rchild;
}
}
}
}