一、题目
给定一个二叉树,返回该二叉树的之字形层序遍历,(第一层从左向右,下一层从右向左,一直这样交替)
二、题解
思路同二叉树的层次遍历,借助队列实现j,只是多了对树深度的奇偶判断和处理,哔站详细讲解
/**
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
class Solution {
public:
/**
*
* @param root TreeNode类
* @return int整型vector<vector<>>
*/
vector<vector<int> > zigzagLevelOrder(TreeNode* root) {
// write code here
vector<vector<int> > res; //最终返回结果
if(root == NULL) return res;
int height = 1;//统计树深度
queue<TreeNode *> Q;
Q.push(root);//根节点入队
while(!Q.empty()){
vector<int> temp;//存储每一层上节点的值
int n = Q.size();//队列大小即为每一层节点的数目
for(int i=0;i<n;i++){
TreeNode * node = Q.front();//取队头第一个元素
Q.pop();
if(height%2 != 0) temp.push_back(node->val);//如果是奇数层,默认在vector尾部插入
else temp.insert(temp.begin(), node->val);//如果是偶数层,指定在vector头部插入
if(node->left != NULL) Q.push(node->left);//如果左子树不为空就递归左子树
if(node->right != NULL) Q.push(node->right);如果右子树不为空就递归左子树
}
height++;
res.push_back(temp);
}
return res;
}
};