//找到以P为根的子树中,第一个被中序遍历的结点
ThreadNode *Firstnode(ThreadNode *p){//循环找到最左下结点(不一定是叶结点)while(p-> == 0) p=p->lchild;return p;
}
//在中序线索二叉树中找到结点p的后继结点
ThreadNode *Nextnode(ThreadNode *p){//右子树最左下结点if(p->rtag == 0) return Firstnode(p->rchild);else return p->rchild;//rtag==1直接返回后继线索
}//对中序线索二叉树进行中序遍历(利用线索实现的非递归算法)
void Inorder(ThreadNode *T){for(ThreadNode *p = Firstnode(T);p!=NULL;p=Nextnode(p))visit(p);
}
//找到以P为根的子树中,最后一个被中序遍历的结点
ThreadNode *Lastnode(ThreadNode *p){//循环找到最右下结点(不一定是叶结点)while(p->rtag == 0) p = p->rchild;return p;
}
//在中序线索二叉树中找到结点p的前驱结点
ThreadNode *Prenode(ThreadNode *p){//左子树中最右下结点if(p->ltag == 0) return Lastnode(p -> lchild);else return p->lchild;//ltag==1直接返回前驱线索
}//对中序线索二叉树进行逆向中序遍历
void RevInorder(ThreadNode *T){for(ThreadNode *p = LastNode(T); p!=NULL ; p=Prenode(p))visit(p);
}
本文发布于:2024-01-29 17:45:20,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170652152717185.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |