二叉树的递归遍历

作者: tingshuo123 | 来源:发表于2017-09-23 19:07 被阅读10次

    二叉树的结构定义

    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

    相关文章

      网友评论

        本文标题:二叉树的递归遍历

        本文链接:https://www.haomeiwen.com/subject/wxacextx.html