Binary Tree Level Order Traversal

本文介绍了一种使用队列实现二叉树层序遍历的方法,通过层序遍历获取二叉树节点值的层级顺序。详细阐述了算法思想,并提供了C++代码实现。

Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level).

For example:
Given binary tree {3,9,20,#,#,15,7},

    3
   / \
  9  20
    /  \
   15   7

return its level order traversal as:

[
  [3],
  [9,20],
  [15,7]
]

思路:这道题同样可以用层序遍历的思想,定义一个队列Q,指针front,rear分别记录每一层节点在Q中的起始坐标和终点坐标,然后遍历取得节点的值即可。

class Solution {
public:
    vector<vector<int> > levelOrder(TreeNode *root) {
        vector<vector<int> > aa;
        vector<int> line;
        int front = 0, rear = -1;
        int index,i;
        if(root == NULL)
        {
            return aa;
        }     
        vector<TreeNode*> Q;
        Q.push_back(root);
        rear = Q.size();
        line.push_back(root->val);
        aa.push_back(line);
        while(front < rear)
        {
            index = rear;
            line.clear();
            for(i=front; i<index; i++)
            {
                if (Q[i]->left != NULL)
                {
                    Q.push_back(Q[i]->left);
                    line.push_back(Q[i]->left->val);
                }   
                if (Q[i]->right != NULL)
                {
                    Q.push_back(Q[i]->right);
                    line.push_back(Q[i]->right->val);
                }  
            }  
            rear = Q.size();
            if (rear != index)
            {
                aa.push_back(line);
            }
            front = index;  
        }  
        return aa;
    }
};




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值