先序遍历二叉树的递归实现与非递归实现深入解析
来源:本站原创|时间:2020-01-10|栏目:C语言|点击: 次
1、先序遍历二叉树 递归实现
思想:若二叉树为空,返回。否则
1)遍历根节点;
2)先序遍历左子树;
3)先序遍历右子树;
代码:
复制代码 代码如下:
template<typename elemType>
void PreOrder(nodeType<elemType> *root)
{
if(root==NULL)
return ;
visit(root->data); // visit the data
PreOrder(root->lchild); //递归调用,先序遍历左子树
PreOrder(root->rchild); //递归调用,先序遍历右子树
}
2、先序遍历二叉树 非递归实现
思想:二叉树的非递归先序遍历,先序遍历思想:先让根进栈,只要栈不为空,就可以做弹出操作, 每次弹出一个结点,记得把它的左右结点都进栈,记得右子树先进栈,这样可以保证右子树在栈中总处于左子树的下面。
前序遍历二叉树的非递归算法思想
建立栈 Stack;
t 指向根;
当 t 不空 或 Stack 不空时反复做:
若 t 不空,访问t,t 入 栈;t 指向左子女;
否则:出栈顶元素到 t 中;
t 指向右子女;
结束
复制代码 代码如下:
void PreOrder_Nonrecursive(BinaryTree T) //先序遍历的非递归
{
if(!T) return ;
stack<BinaryTree> s;
s.push(T);
while(!s.empty())
{
BinaryTree temp = s.top();
visit(temp->data);
s.pop();
if(temp->rchild)
s.push(temp->rchild);
if(temp->lchild)
s.push(temp->lchild);
}
}
您可能感兴趣的文章
- 01-10深入二叉树两个结点的最低共同父结点的详解
- 01-10深入理解二叉树的非递归遍历
- 01-10深入遍历二叉树的各种操作详解(非递归遍历)
- 01-10判断整数序列是否为二元查找树的后序遍历结果的解决方法
- 01-10探讨:C++实现链式二叉树(用非递归方式先序,中序,后序遍历二叉树
- 01-10如何在二叉树中找出和为某一值的所有路径
- 01-10深入linux下遍历目录树的方法总结分析
- 01-10深入探讨:linux中遍历文件夹下的所有文件
- 01-10c++ builder TreeView控件节点遍历代码
- 01-10二叉搜索树的插入与删除(详细解析)
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 01-11ajax实现页面的局部加载
- 04-02jquery与jsp,用jquery
- 01-10delphi制作wav文件的方法
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-10SublimeText编译C开发环境设置
- 01-10C#中split用法实例总结
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文