102. Binary Tree Level Order Traversal (Tree, Queue; BFS)

Posted joannae

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了102. Binary Tree Level Order Traversal (Tree, Queue; BFS)相关的知识,希望对你有一定的参考价值。

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,null,null,15,7],

    3
   / \
  9  20
    /  \
   15   7

return its level order traversal as:

[
  [3],
  [9,20],
  [15,7]
]
思路:层次遍历用队列来实现,这里因为需要知道在哪一层,所以需要用两个队列/或者创建一个数据结构,包含TreeNode以及level信息。

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<queue<TreeNode*>> q(2);
        int curIndex = 0;
        int nextIndex = 1;
        vector<int> retItem;
        vector<vector<int>> ret;
        
        if(root) q[curIndex].push(root);
        while(!q[curIndex].empty()){
            retItem.push_back(q[curIndex].front()->val);
            if(q[curIndex].front()->left) q[nextIndex].push(q[curIndex].front()->left);
            if(q[curIndex].front()->right) q[nextIndex].push(q[curIndex].front()->right);
            q[curIndex].pop();
            
            if(q[curIndex].empty()){ //end of this level
                ret.push_back(retItem);
                retItem.clear();
                curIndex = (curIndex+1) & 0x01;
                nextIndex = (nextIndex+1) & 0x01;
            }
        }
        
        return ret;
    }
};

 

以上是关于102. Binary Tree Level Order Traversal (Tree, Queue; BFS)的主要内容,如果未能解决你的问题,请参考以下文章

102. Binary Tree Level Order Traversal

LeetCode102. Binary Tree Level Order Traversal

102Binary Tree Level Order Traversal

102. Binary Tree Level Order Traversal

Leetcode 102. Binary Tree Level Order Traversal

[LeetCode]题解(python):102 Binary Tree Level Order Traversal