【队列】求二叉树的层序遍历

求解代码

构建一个辅助队列queue,让root首先进入队列。

java 复制代码
public ArrayList<ArrayList<Integer>> levelOrder (TreeNode root) {
        ArrayList<ArrayList<Integer>> ans = new ArrayList<>();

		if(root==null){
			return ans;
		}
		Queue<TreeNode> queue = new ArrayDeque<TreeNode>();
		queue.add(root);

		while(!queue.isEmpty()){
			ArrayList<Integer> list = new ArrayList<>();

			int n = queue.size();

			for(int i=0;i<n;i++){
				TreeNode cur = queue.poll();
				list.add(cur.val);

				if (cur.left!=null) {
					queue.add(cur.left);
				}
				
				if(cur.right!=null){
					queue.add(cur.right);
				}
			}
			ans.add(list);
		}

		return ans;
    }
相关推荐
小肝一下8 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
语戚10 小时前
力扣 51. N 皇后:基础回溯、布尔数组优化、位运算全解(Java 实现)
java·算法·leetcode·力扣·剪枝·回溯·位运算
py有趣10 小时前
力扣热门100题之螺旋矩阵
算法·leetcode
人道领域10 小时前
【LeetCode刷题日记】383 赎金信
算法·leetcode·职场和发展
旖-旎10 小时前
哈希表(存在重复元素)(3)
数据结构·c++·学习·算法·leetcode·散列表
Tisfy11 小时前
LeetCode 3740.三个相等元素之间的最小距离 I:今日先暴力,“明日“再哈希
算法·leetcode·哈希算法·题解·模拟·遍历·暴力
我真不是小鱼11 小时前
cpp刷题打卡记录27——无重复字符的最长子串 & 找到字符串中所有字母的异位词
数据结构·c++·算法·leetcode
We་ct11 小时前
LeetCode 69. x 的平方根:两种解法详解
前端·javascript·算法·leetcode·typescript·平方
穿条秋裤到处跑12 小时前
每日一道leetcode(2026.04.09):区间乘法查询后的异或 II
算法·leetcode
小欣加油12 小时前
leetcode 42 接雨水
c++·算法·leetcode·职场和发展