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

 

全部评论

相关推荐

2025-12-04 14:15
杭州电子科技大学 C++
点赞 评论 收藏
分享
2025-12-06 01:10
已编辑
哈尔滨工程大学 Java
一面问的真细,二面不知为啥变双机位。9.29快手主站平时怎么学习&nbsp;AI&nbsp;的,国内外知名大模型,实习公司都用的什么大模型,怎么评估效果的java池化思想,线程池构造方法的核心参数,线程池中阻塞队列注意事项,submit方法参数和执行逻辑,shutdown和shutdownnow,核心线程允许过期吗threadlocal底层,为什么key是弱引用,key回收了再get或者set这个value会怎样aqs,如何保证公平性java代理java堆划分,新生代还有别的晋升老年代的情况吗,什么时候触发gc,gc失败抛什么异常,如何排查oom,导出dump命令redis数据结构,哪个底层是跳表,和其他数据结构对比布隆过滤器会出现大key问题吗,你咋实现的布隆过滤器你怎么实现redis分布式锁,可重入,续期聚簇索引非聚簇索引select语句会加锁吗,怎么实现的不加锁undolog&nbsp;redolog&nbsp;binlog怎么能让select加锁,update这个范围加的什么锁,update一条呢手撕简单01背包,接雨水10.10快手主站意图识别用的哪个大模型,走到意图和rag的比例,faq是点击的吗自然语言怎么识别的gap一年干啥了,转正怎么样没跟组里提意向吗,研究生研究方向是传统算法吗,会大模型微调吗注册场景为什么用布隆过滤器,原理分布式锁底层的key怎么拼的,value里是什么redis持久化zset底层mysql索引结构,一个表三个字段有主键唯一索引和没索引的字段会有几个b+树,聚簇索引非聚簇索引存的啥无手撕
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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