typedef struct TreeNode *BinTree;
typedef BinTree Position;
struct TreeNode{
ElementType Data;
BinTree Left;
BinTree Right;
};
BinTree BT;
void InOrderTraversal(BinTree BT)//中序遍历非递归遍历算法(使用堆栈,用循环实现)
{
BinTree T=BT;
Stack S=CreakStack(MaxSize);//创建并初始化堆栈S
while(T||!IsEmpty(S)){
while(T){//一直向左并将沿途结点压入堆栈
Push(S,T);
T=T->Left;
}
if(!IsEmpty(S)){
T=Pop(S);//结点弹出堆栈
printf("%5d",T->Data);//(访问)打印结点
T=T->Right;//转向右子树
}
}
}
void PreOrderTraversal(BinTree BT)//先序遍历非递归遍历算法(使用堆栈,用循环实现)
{
BinTree T=BT;
Stack S=CreakStack(MaxSize);//创建并初始化堆栈S
while(T||!IsEmpty(S)){
while(T){//一直向左并将沿途结点压入堆栈
printf("%5d",T->Data);//(访问)打印结点
Push(S,T);
T=T->Left;
}
if(!IsEmpty(S)){
T=Pop(S);//结点弹出堆栈
T=T->Right;//转向右子树
}
}
}
void PostOrderTraversal( BinTree BT )//后序遍历非递归遍历算法(使用堆栈,用循环实现)
{
BinTree T BT;
Stack S = CreatStack( MaxSize ); /*创建并初始化堆栈S*/
Stack Q = CreatStack( MaxSize ); /*创建并初始化堆栈Q,用于输出反向*/
while( T || !IsEmpty(S) ){
while(T){ /*一直向右并将沿途结点压入堆栈*/
Push(S,T);
Push(Q,T);/*将遍历到的结点压栈,用于反向*/
T = T->Right;
}
if(!IsEmpty(S)){
T = Pop(S); /*结点弹出堆栈*/
T = T->Left; /*转向左子树*/
}
}
while( !IsEmpty(Q) ){
T = Pop(Q);
printf(“%5d”, T->Data); /*(访问)打印结点*/
}
}
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。