题目描述
yac大佬的视频是在每一行的末尾加上nullptr,其实也可以统计每一行有多少个元素,以达到分行的目的,这种bfs的方法是,记录每一行的元素个数,并在pop该行元素的同时,将该元素的非空的左右节点加入到队列中。
算法1
(bfs) $O(n)$
C++ 代码
/**
* 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>> printFromTopToBottom(TreeNode* root) {
vector<vector<int>> res;
if(!root) return res;
queue<TreeNode*> q;
q.push(root);
while(q.size())
{
vector<int> t;
int n = q.size();
for(int i = 0; i < n; i ++ )
{
auto p = q.front();
q.pop();
t.push_back(p -> val);
if(p -> left ) q.push(p -> left);
if(p -> right ) q.push(p -> right);
}
res.push_back(t);
}
return res;
}
};
妙啊。优雅!
优雅