LeetCode 103. 二叉树的锯齿形层序遍历
Posted Blocking The Sky
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 103. 二叉树的锯齿形层序遍历相关的知识,希望对你有一定的参考价值。
给定一个二叉树,返回其节点值的锯齿形层序遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。
class Solution
public:
vector<vector<int>> zigzagLevelOrder(TreeNode* root)
vector<vector<int>> result;
queue<TreeNode*> q;
stack<int> s;//辅助栈
TreeNode* p;
bool flag=true;//奇偶数层的标志
if(root)
q.push(root);
while(!q.empty())
int size=q.size();
vector<int> level;
for(int i=0;i<size;i++)
p=q.front();
q.pop();
if(flag)
level.push_back(p->val);
else
s.push(p->val);
if(p->left)
q.push(p->left);
if(p->right)
q.push(p->right);
if(!flag)
while(!s.empty())
level.push_back(s.top());
s.pop();
result.push_back(level);
flag=!flag;//更新层次奇偶性
return result;
;
以上是关于LeetCode 103. 二叉树的锯齿形层序遍历的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode第103题—二叉树的锯齿形层序遍历—Python实现