题目描述:从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。 解题思路:这道题其实就是层序遍历二叉树并依次输出每层二叉树的元素。先建立一个队列,根结点入队,取队列大小为l。在for(i=0;i<l;i++)中队首元素依次压入容器vector,然后出队。若根结点有左右孩子则将左右孩子入队。 代码: /** * 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<vector<int>>res; if(root==NULL) return res; queue<TreeNode*>q; q.push(root); while(!q.empty()){ vector<int>r; int l=q.size(); for(int i=0;i<l;i++){ TreeNode*t=q.front(); r.push_back(t->val); q.pop(); if(t->left) q.push(t->left); if(t->right) q.push(t->right); } res.push_back(r); } return res; } };