二叉树三种遍历方式的六种实现方法

本文详细介绍了二叉树的三种遍历方法:先序遍历、中序遍历和后序遍历。分别通过递归和非递归的方式实现,并提供了相应的代码示例。先序遍历顺序为根节点-左孩子-右孩子,中序遍历顺序为左孩子-根节点-右孩子,后序遍历顺序为左孩子-右孩子-根节点。对于非递归实现,利用栈结构巧妙地调整了遍历顺序,以达到预期的效果。
摘要由CSDN通过智能技术生成

方法一:先序遍历:
遍历顺序:根节点–>左孩子–>右孩子
在这里插入图片描述
遍历顺序:A–>B–>D–>H–>I–>E–>J–>C–>F–>G
先序遍历的递归实现:
很简单,自己想一下递归的过程就行
代码如下:

#include<bits/stdc++.h.
using namespace std;
struct node//这是二叉树的基本结构
{
    node left;
    node right;
    int value;
};
void preorder(node head)//传进来的是二叉树的头节点,即数顶部的节点  先序遍历
{
    if(head==null)
        return ;
    cout<<head.value<<" ";
    preorder(head.left);
    preorder(head.right);
}
先序遍历的非递归实现:

运用了一个栈结构实现。

思路:
先序遍历的遍历顺序为根节点–>左孩子–>右孩子,所以往栈中放数时先放右孩子,在放左孩子(左右孩子都不为空的情况下)。根据栈的先进后出的性质,所以先打印左孩子再打印右孩子,但是有的人可能会有疑问,那根节点呢。根节点在往栈中放左右孩子的时候就已经打印完了,所以根节点肯定在左右孩子打印之前就打印完了。
这样打印顺序就为:根节点–>左孩子–>

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

N1314N

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值