题解 | #求二叉树的层序遍历#
求二叉树的层序遍历
https://www.nowcoder.com/practice/04a5560e43e24e9db4595865dc9c63a3
/**
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* };
*/
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param root TreeNode类
* @return int整型vector<vector<>>
*/
vector<vector<int> > levelOrder(TreeNode* root) {
// write code here
vector<vector<int>> w;
if (root==nullptr) return w;
queue<TreeNode*>tree;
tree.push(root);
while (!tree.empty()) {
vector<int> v;
int size = tree.size();
while (size--) {
root = tree.front();
tree.pop();
v.push_back(root->val);
if (root->left) tree.push(root->left);
if (root->right) tree.push(root->right);
}
w.push_back(v);
}
return w;
}
};
层次遍历,顺序为根节点,左节点,右节点。左节点得左节点、右节点。首先对根节点判断是否为空。 如果不为空,根节点入队。这是第一层,加入vector容器中,使用size来记录队的长度。什么情况下入队?当前队首元素的左孩子存在则入队左孩子,右孩子存在再入队右孩子。对第二层来说,队首第一个节点是第二层最左边的节点。层次遍历要把所有的一层都遍历完才到下一层。那么也就是说,我需要把这一层,每一个节点的左孩子节点和右孩子节点都判断一下处理入队操作。这样出队的时候顺序就是层次遍历的顺序,但是需要注意每一层都要放在一个vector中。
realme公司福利 325人发布