leetcode 102. 二叉树的层次遍历 Binary Tree Level Order Traversal(使用c++/java/python)【使用并总结队列】

https://leetcode-cn.com/problems/binary-tree-level-order-traversal/

https://leetcode.com/problems/binary-tree-level-order-traversal/

使用队列保存待处理的结点;使用双层vector/list保存每层的结点值。

初始状态将根节点入队,然后每次初始化一个单层vector/list保存本层结点值。

本层结点个数就是当前队列中的元素个数,因为当第n层处理完时,第n层结点的左右孩子都已入队,队中元素即是n+1层的有效结点数。

对于每一层,先将队首出队,再将其左右孩子中非空的结点入队,队首的值进入本层的vector/list

 

执行用时: c++ 16ms; java 1ms; python 52ms

队列常用操作:

  c++ java python
队列 queue Queue collections.deque
访问队首 front() peek()  
弹出队首 pop() (但不返回) poll() popleft()
进队 push() offer() append()
队为空 empty() isEmpty()  
队大小 size() size() len()

 

 

c++

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<vector<int>> res;
        if(root==NULL) return res;
        
        queue<TreeNode*> que;
        que.push(root);
        while(!que.empty())
        {
            vector<int> lev;
            int levnum = que.size();
            for(int i=0;i<levnum;i++)
            {
                TreeNode* head = que.front();
                que.pop();
                if(head->left) que.push(head->left);
                if(head->right) que.push(head->right);
                lev.push_back(head->val);
            }
            res.push_back(lev);
        }
        return res;
    }
};

 

java

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> res = new LinkedList<List<Integer>>();
        if(root==null) return res;
        
        Queue<TreeNode> que = new LinkedList<TreeNode>();
        que.offer(root);
        while(!que.isEmpty())
        {
            List<Integer> lev = new LinkedList<Integer>();
            int levnum = que.size();
            for(int i=0;i<levnum;i++)
            {
                TreeNode head = que.poll();
                if(head.left!=null) que.offer(head.left);
                if(head.right!=null) que.offer(head.right);
                lev.add(head.val);
            }
            res.add(lev);
        }
        return res;
    }
}

 

python

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def levelOrder(self, root):
        """
        :type root: TreeNode
        :rtype: List[List[int]]
        """
        res = []  #嵌套列表,保存最终结果
        if root is None:
            return res
        
        from collections import deque
        que = deque([root])  #队列,保存待处理的结点
        while len(que)!=0:
            lev = []  #列表,保存该层的结点的值
            thislevel = len(que)  #该层结点个数
            while thislevel!=0:
                head = que.popleft()  #弹出队首结点
                #队首结点的左右孩子入队
                if head.left is not None:
                    que.append(head.left)
                if head.right is not None:
                    que.append(head.right)
                lev.append(head.val)  #队首结点的值压入本层
                thislevel-=1
            res.append(lev)
        return res

 

全部评论

相关推荐

大方的大熊猫准备进厂:1.教育背景:你希望从事什么专业的工作你的主修课就是什么;成绩优秀是你应该做的,没什么可描述的,成绩不优秀也许人家在大学忙着创业呢?(成绩优秀不一定是好事,只能说明多元化的大学你上成了高中,没有真正上明白大学,反而体现了你死板,不爱社交,没有别的突出能力) 2.实践经历:你想表达的意思没有说清楚。你是说你会个性化服务,还是你有实习经历。如果没有带来,经济收益,表彰,更好的发展前景,那你还不如说说提升了自己哪些技能。你说有人给你送锦旗我都能明白你优秀,但是你说你会xxxx,你说这话谁信,证据呢。 3.入伍经历:你描述的就是你的工作职责或者你应该做的,并没有体现出来你把这个事情做好了,而且入伍经历并不能证明你能干好你要应聘的工作,不如只写经历其余所有内容都不写。 4.荣誉技能:重点突出一下,但不要过多描述,这些荣誉的含金量懂得都懂。 重点:你要应聘什么工作(具体岗位,实习生不具体),你的期望薪资
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务