LCR.P151[彩灯装饰记录III] 方法一:BFS12345678910111213141516171819202122232425262728293031323334353637/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */class Solution { public List<List<Integer>> decorateRecord(TreeNode root) { List<List<Integer>> ans = new ArrayList<>(); Deque<TreeNode> queue = new ArrayDeque<>(); if (root != null) queue.offer(root); boolean flag = true; while (!queue.isEmpty()) { int size = queue.size(); List<Integer> list = new ArrayList<>(); while (size-- > 0) { TreeNode cur = queue.poll(); list.add(cur.val); if (cur.left != null) queue.offer(cur.left); if (cur.right != null) queue.offer(cur.right); } if (!flag) Collections.reverse(list); ans.add(list); flag = !flag; } return ans; }} 时间复杂度:$O(n)$ 空间复杂度:$O(n)$