遍历二叉树的四种办法C++

四种常用的遍历二叉树的算法:

  • DLR先序遍历
  • LDR中序遍历
  • LRD后序遍历
  • 层次遍历

以下是简单的C++实现

#include <iostream>
#include <queue>

using namespace std;

typedef char ElemType;
typedef struct BNode {
    ElemType data;
    struct BNode *lchild, *rchild;
}BNode, *BTree;

void func(BTree &T) {
    cout << T->data << endl;
}

void createByNote(BTree &T) {
    char ch;
    cin >> ch;
    if (ch == '#')
        T = NULL;
    else {
        T = new BNode;
        T->data = ch;
        createByNote(T->lchild);
        createByNote(T->rchild);
    }
}

void preOrder(BTree T) {
    if (T) {
        func(T);
        preOrder(T->lchild);
        preOrder(T->rchild);
    }
}

void inOrder(BTree T) {
    if (T) {
        inOrder(T->lchild);
        func(T);
        inOrder(T->rchild);
    }
}

void posOrder(BTree T) {
    if (T) {
        posOrder(T->lchild);
        posOrder(T->rchild);
        func(T);
    }
}

void a(BTree T) {
    cout << "preOrder:" << endl;
    preOrder(T);
    cout << "inOrder:" << endl;
    inOrder(T);
    cout << "posOrder:" << endl;
    posOrder(T);
}

bool levelTraverse(BTree T) {
    if (!T) return false;

    BTree p;
    queue<BTree> Q;
    Q.push(T);

    while (!Q.empty()) {
        p = Q.front();
        Q.pop();
        func(T);
        if (p->lchild != NULL)
            Q.push(p->lchild);
        if (p->rchild != NULL)
            Q.push(p->rchild);
    }
    return true;
}

int main() {
    BTree T1;
    createByNote(T1);
    levelTraverse(T1);
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 二叉树的遍历 二叉树遍历 分为前序遍历、中序遍历和后序遍历。 前序遍历 (DLR) 先访问根节点,然后前序遍历左子...
    xiaoyouPrince阅读 1,082评论 0 0
  • 一直以来,我都很少使用也避免使用到树和图,总觉得它们神秘而又复杂,但是树在一些运算和查找中也不可避免的要使用到,那...
    24K男阅读 6,782评论 5 14
  • 树和二叉树 一种非线性结构。树是递归结构,在树的定义中又用到了树的概念。 基本术语: 树结点:包含一个数据元素及若...
    北风知我意阅读 555评论 0 0
  • 目录 1、什么是树 2、相关术语 3、二叉树 3.1、二叉树的类型 3.2、二叉树的性质 3.3、二叉树的结构 3...
    我哈啊哈啊哈阅读 2,588评论 0 10
  • 树的定义与基本术语   树型结构是一类重要的非线性数据结构,其中以树和二叉树最为常用,是以分支关系定义的层次结构。...
    java技术分享师阅读 1,136评论 0 1