Binary Tree Zigzag Level Order Traversal
来源:互联网 发布:淘宝二次元 编辑:程序博客网 时间:2024/04/29 07:42
题目:
Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to right, then right to left for the next level and alternate between).
For example:
Given binary tree {3,9,20,#,#,15,7}
,
3 / \ 9 20 / \ 15 7
return its zigzag level order traversal as:
[ [3], [20,9], [15,7]]
代码如下:
void getleverorder(TreeNode *root,vector<vector<int> > &getnode,int i)
{
if(root!=NULL)
{
if(i>getnode.size())
{
vector<int> tmp;
tmp.push_back(root->val);
getnode.push_back(tmp);
}
else
{
getnode[i-1].push_back(root->val);
}
getleverorder(root->left,getnode,i+1);
getleverorder(root->right,getnode,i+1);
}
return;
}
void swap(vector<int> &tmp)
{
int n=tmp.size()-1,i=0;
while(i<n)
{
int t=tmp[i];
tmp[i++]=tmp[n];
tmp[n--]=t;
}
return;
}
vector<vector<int> > zigzagLevelOrder(TreeNode *root) {
vector<vector<int> > getnode;
int i=1;
getleverorder(root,getnode,i);
for(int i=0;i<getnode.size();i++)
{
if(i%2==1)
{
swap(getnode[i]);
}
}
return getnode;
}
- LeetCode: Binary Tree Zigzag Level Order Traversal
- [LeetCode]Binary Tree Zigzag Level Order Traversal
- LeetCode Binary Tree Zigzag Level Order Traversal
- [Leetcode] Binary Tree Zigzag Level Order Traversal
- Leetcode: Binary Tree Zigzag Level Order Traversal
- LeetCode Binary Tree Zigzag Level Order Traversal
- [LeetCode] Binary Tree Zigzag Level Order Traversal
- [Leetcode] Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal
- 【leetcode】Binary Tree Zigzag Level Order Traversal
- [LeetCode]Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal
- [Leetcode]Binary Tree Zigzag Level Order Traversal
- [leetcode]Binary Tree Zigzag Level Order Traversal
- Leetcode: Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal
- Write operations are not allowed in read-only mode (FlushMode.NEVER/MANUAL)
- 三色球问题
- Super Jumping! Jumping! Jumping!(DP)
- 无限式查找
- OpenCV图像中寻找最大区域Max_Area
- Binary Tree Zigzag Level Order Traversal
- 命运(DP)
- 位运算实现加法--2013-06-01
- JavaFX 各种内建built-in布局管理器的使用
- 免费馅饼(DP,类比数塔)
- Java反射基本使用方法 示例
- TopCoder 250 points 16-SRM 151 DIV 2 97.63/250 39.05%
- 支持向量机通俗导论(理解SVM的三层境界)
- OpenCV图像Surf与flann特征点