二叉树的递归遍历

二叉树的结构定义

typedef struct TNode *Position;
typedef Position BinTree;

 // 二叉树树节点的定义
struct TNode {
    ElementType Data;  // 节点数据
    BinTree Left;  // 左子树
    BinTree Right;  // 右子树
};

二叉树的遍历

对二叉树的遍历是指访问树的每个结点,且每个结点仅被访问一次。访问是一个抽象的概念,实际上可以对结点数据的各种处理,比如输出结点信息。下面的遍历都是先遍历左子树再遍历右子树,根据访问其结点的先后进行区分

中序遍历

中序遍历是指对树中任一结点的访问是在遍历完其左子树后进行的,访问此结点后再对其右子树遍历。从根结点开始,遇到每个结点是,做以下处理:

  1. 中序遍历其左子树
  2. 访问根结点
  3. 中序遍历其右子树
void InOrderTraversal( BinTree BT )
{
    if ( BT ) {
        InOrderTraversal( BT->Left );  //1
        printf( "%d", BT->Data );  //2
        InOrderTraversal( BT->Right  );  //3
    }
}

先序遍历

先序遍历是指对结点的访问是再其左、右子树遍历之前进行的。从根结点开始,遇到每个结点是,做以下处理:

  1. 访问根结点
  2. 先序遍历其左子树
  3. 先序遍历其右子树
void InOrderTraversal( BinTree BT )
{
    if ( BT ) {
        printf( "%d", BT->Data );  //1
        InOrderTraversal( BT->Left );  //2
        InOrderTraversal( BT->Right  );  //3
    }
}

后续遍历

后续遍历是指结点左、右子树的遍历先进行,然后才是对此节点的访问。从根结点开始,遇到每个结点是,做以下处理:

  1. 后续遍历其左子树
  2. 后续遍历其右子树
  3. 访问根结点
void InOrderTraversal( BinTree BT )
{
    if ( BT ) {
        InOrderTraversal( BT->Left );  //1
        InOrderTraversal( BT->Right  );  //2
        printf( "%d", BT->Data );  //3
    }
}

下图为对该二叉树进行各种遍历的结果:


遍历结果.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 数据结构和算法--二叉树的实现 几种二叉树 1、二叉树 和普通的树相比,二叉树有如下特点: 每个结点最多只有两棵子...
    sunhaiyu阅读 6,529评论 0 14
  • 对于二叉树T,可以递归定义它的先序遍历、中序遍历和后序遍历,如下所示: PreOrder(T)=T的根结点+Pre...
    Gaolex阅读 451评论 0 1
  • 相关概念 「树的遍历」 指按照一定规则不重复地访问树中所有节点的过程。「访问」指针对节点的操作,如打印节点的值,更...
    nbb3210阅读 1,879评论 0 1
  • 四、树与二叉树 1. 二叉树的顺序存储结构 二叉树的顺序存储就是用数组存储二叉树。二叉树的每个结点在顺序存储中都有...
    MinoyJet阅读 1,585评论 0 7
  • B树的定义 一棵m阶的B树满足下列条件: 树中每个结点至多有m个孩子。 除根结点和叶子结点外,其它每个结点至少有m...
    文档随手记阅读 13,341评论 0 25