首页 > 其他 > 详细

LeetCode OJ:Binary Tree Level Order Traversal(二叉树的层序遍历)

时间:2015-10-23 21:21:53      阅读:254      评论:0      收藏:0      [点我收藏+]

Given a binary tree, return the level order traversal of its nodes‘ values. (ie, from left to right, level by level).

For example:
Given binary tree {3,9,20,#,#,15,7},

    3
   /   9  20
    /     15   7

return its level order traversal as:

[
  [3],
  [9,20],
  [15,7]
]

层序遍历,既可以用dfs实现也可以用bfs实现,用bfs实现的时候应该借助队列,代码如下:

dfs:

 1 class Solution {
 2 public:
 3     vector<vector<int>> levelOrder(TreeNode* root) {
 4         dfs(root, 0);
 5         return ret;
 6     }
 7     void dfs(TreeNode * root, int dep)
 8     {
 9         if(!root) return;
10         if(dep < ret.size()){
11             ret[dep].push_back(root->val);
12         }else{
13             vector<int> tmp;
14             tmp.push_back(root->val);
15             ret.push_back(tmp);
16         }
17         dfs(root->left, dep+1);
18         dfs(root->right, dep+1);
19     }
20 private:
21     vector<vector<int>> ret;
22 };

bfs:

 1 class Solution {
 2 private:
 3     struct Node{
 4         TreeNode * treeNode;
 5         int level;
 6         Node(){}
 7         Node(TreeNode * node, int lv)
 8         :treeNode(node), level(lv){}
 9     };
10 public:
11     vector<vector<int>> levelOrder(TreeNode* root) {
12         queue<Node> nodeQueue;
13         vector<vector<int>> ret;
14         if(root == NULL)
15             return ret;
16         nodeQueue.push(Node(root, 0));
17         int dep = -1;
18         while(!nodeQueue.empty()){
19             Node node = nodeQueue.front();
20             if(node.treeNode->left)
21                 nodeQueue.push(Node(node.treeNode->left, node.level + 1));
22             if(node.treeNode->right)
23                 nodeQueue.push(Node(node.treeNode->right, node.level + 1));
24             if(dep == node.level)
25                 ret[dep].push_back(node.treeNode->val);
26             else{
27                 vector<int> tmp;
28                 dep++;
29                 ret.push_back(tmp);
30                 ret[dep].push_back(node.treeNode->val);
31             }
32             nodeQueue.pop();
33         }
34         return ret;
35     }
36 };

 

LeetCode OJ:Binary Tree Level Order Traversal(二叉树的层序遍历)

原文:http://www.cnblogs.com/-wang-cheng/p/4905683.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!