二叉树前序遍历的非递归算法
2019/7/10 23:17:43
本文主要是介绍二叉树前序遍历的非递归算法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
二叉树的前序遍历是先根节点,然后如果有左子树则再先序遍历左子树,然后如果有右子树则再先序遍历其又子树。
递归算法如下
void preorder(Betree *t)
{ if(t==null) return;visit(t);//访问该节点preorder(t->lchild);preorder(t->rchild); }
当然递归算法是隐式使用了栈。我们仔细分析这个过程,先是取出了根节点进行了访问,然后我们把根节点退栈,退栈后必然有节点进栈,怎么办呢?根节点只能直接访问到rchild和lchild,如果是左子树的根节点进了栈,那么必然是后访问之,所以必然是rchild先进栈,lchild后进栈。可以画图加深理解。
那么现在写出先序遍历二叉树的算法。
void preorder(Betree *t)
{ //算法中我们使用一维数组来模拟一个顺序栈
if(t==null) return;//为空树的话完全没有必要进行下面的操作
Betree *stack[max];
top=1;stack[top]=t;//根节点入栈
while(top>0)
{ nd=stack[top];//取出根节点 top=top-1;//退栈 visit(nd->data); //访问根节点 if(nd->rchild!=null) { top=top+1;stack[top]=nd->rchild;} //根节点有右子树,将其进栈,等到左子树访问完后再访问之
if(nd->lchild!=null) { top=top+1;stack[top]=nd->lchild;}
}
}
递归算法如下
复制代码 代码如下:
void preorder(Betree *t)
{ if(t==null) return;visit(t);//访问该节点preorder(t->lchild);preorder(t->rchild); }
当然递归算法是隐式使用了栈。我们仔细分析这个过程,先是取出了根节点进行了访问,然后我们把根节点退栈,退栈后必然有节点进栈,怎么办呢?根节点只能直接访问到rchild和lchild,如果是左子树的根节点进了栈,那么必然是后访问之,所以必然是rchild先进栈,lchild后进栈。可以画图加深理解。
那么现在写出先序遍历二叉树的算法。
复制代码 代码如下:
void preorder(Betree *t)
{ //算法中我们使用一维数组来模拟一个顺序栈
if(t==null) return;//为空树的话完全没有必要进行下面的操作
Betree *stack[max];
top=1;stack[top]=t;//根节点入栈
while(top>0)
{ nd=stack[top];//取出根节点 top=top-1;//退栈 visit(nd->data); //访问根节点 if(nd->rchild!=null) { top=top+1;stack[top]=nd->rchild;} //根节点有右子树,将其进栈,等到左子树访问完后再访问之
if(nd->lchild!=null) { top=top+1;stack[top]=nd->lchild;}
}
}
这篇关于二叉树前序遍历的非递归算法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-28pyqt 怎么打包整个项目-icode9专业技术文章分享
- 2024-09-28laravel Commands 创建带有参数的 Artisan 命令的步骤和示例-icode9专业技术文章分享
- 2024-09-28antd怎么实现渲染tiff图片-icode9专业技术文章分享
- 2024-09-28英文半角中划线和中文全角的中划线有什么区别-icode9专业技术文章分享
- 2024-09-28nvm npm 和node 他们之间有什么关系-icode9专业技术文章分享
- 2024-09-28Node Version Manager (nvm)使用教程-icode9专业技术文章分享
- 2024-09-28nvm命令太慢,是什么原因-icode9专业技术文章分享
- 2024-09-28Kotlin 如何增加、删除和修改 MutableStateFlow 中的值。-icode9专业技术文章分享
- 2024-09-28Kotlin的stateFlow.update 写法介绍-icode9专业技术文章分享
- 2024-09-28kotlin 怎么获取当前时间格式-icode9专业技术文章分享