码迷,mamicode.com
首页 > 编程语言 > 详细

二叉树的层序遍历--结合递归算法

时间:2019-05-14 09:30:04      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:content   pre   lan   顺序   code   技术   var   bit   规则   

层序遍历

规则是:若树为空,则空操作返回,否则从树的第一层,也就是根结点开始访问,从上而下逐层遍历,在同一层中,按从左到右的顺序对结点逐个访问。如图:
技术图片

代码实现


BiTree TreeQueue[1024];
int front = 0;
int rear = 0;
int LevelOrderTraverse(BiTree T) {
    if (!isTreeExits) {
        cout << "二叉树不存在";
        return -1;
    }
    if (!T&&isRoot==0) {
        cout << "二叉树为空,无元素";
    }

    if (T) {
        isRoot++;
        cout << T->data << " ";
        if (T->lchild) {
            TreeQueue[rear] = T->lchild;
            rear++;
        }
        if (T->rchild) {
            TreeQueue[rear] = T->rchild;
            rear++;
        }
        if (front != rear) {
            LevelOrderTraverse(TreeQueue[front++]);
        }
    }
}

二叉树的层序遍历--结合递归算法

标签:content   pre   lan   顺序   code   技术   var   bit   规则   

原文地址:https://www.cnblogs.com/HenuAJY/p/10860232.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!