LeetCode之Binary Tree Zigzag Level Order Traversal
2014-04-05 14:26
316 查看
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},
return its zigzag level order traversal as:
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<vector<int> > zigzagLevelOrder(TreeNode *root) {
vector<vector<int>> rst;
BFS(root,0,rst);
for(int i=1;i<rst.size();i+=2){
reverse(rst[i].begin(),rst[i].end());
}
return rst;
}
void BFS(TreeNode *root, int level, vector<vector<int> > &rst) {
if(!root)return ;
if(level>=rst.size()) rst.push_back(vector<int>());
rst[level].push_back(root->val);
BFS(root->left,level+1,rst);
BFS(root->right,level+1,rst);
}
};
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] ]
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<vector<int> > zigzagLevelOrder(TreeNode *root) {
vector<vector<int>> rst;
BFS(root,0,rst);
for(int i=1;i<rst.size();i+=2){
reverse(rst[i].begin(),rst[i].end());
}
return rst;
}
void BFS(TreeNode *root, int level, vector<vector<int> > &rst) {
if(!root)return ;
if(level>=rst.size()) rst.push_back(vector<int>());
rst[level].push_back(root->val);
BFS(root->left,level+1,rst);
BFS(root->right,level+1,rst);
}
};
相关文章推荐
- LeetCode-Binary Tree Zigzag Level Order Traversal
- 【Leetcode】【python】Binary Tree Zigzag Level Order Traversal
- [LeetCode] Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal 【leetcode】
- 103.leetcode Binary Tree Zigzag Level Order Traversal(medium)[二叉树 栈]
- Leetcode 103 ,Binary Tree Zigzag Level Order Traversal(二叉树Z形分层遍历)
- C++详解Leetcode:103. Binary Tree Zigzag Level Order Traversal
- LeetCode 49 Binary Tree Zigzag Level Order Traversal
- [leetCode]Binary Tree Zigzag Level Order Traversal
- [LeetCode] Binary Tree Zigzag Level Order Traversal
- LeetCode 103 Binary Tree Zigzag Level Order Traversal(二叉树层序遍历)
- [LeetCode#103]Binary Tree Zigzag Level Order Traversal
- LeetCode – Refresh – Binary Tree Zigzag Level Order Traversal
- leetcode -day24 Maximum Depth of Binary Tree & Binary Tree Zigzag Level Order Traversal
- LeetCode 103 Binary Tree Zigzag Level Order Traversal
- LeetCode - Binary Tree Zigzag Level Order Traversal
- Binary Tree Zigzag Level Order Traversal -- leetcode
- LeetCode刷题(C++)——Binary Tree Zigzag Level Order Traversal(Medium)
- 70_leetcode_Binary Tree Zigzag level order traversal
- 【leetcode】Binary Tree Zigzag Level Order Traversal