Last updated on 2023年9月29日 上午
102. 二叉树的层序遍(Java实现)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
| /** * 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>> levelOrder(TreeNode root) { List<List<Integer>> result = new ArrayList<>(); if(root == null){ return result; } Queue<TreeNode> que = new LinkedList<>(); que.offer(root);
while(!que.isEmpty()){ List<Integer> tmpList = new ArrayList<>(); int len = que.size(); for(int i = 0;i < len;i++){ TreeNode tmpNode = que.poll(); tmpList.add(tmpNode.val); if(tmpNode.left != null){ que.offer(tmpNode.left); } if(tmpNode.right != null){ que.offer(tmpNode.right); } } result.add(tmpList); } return result; } }
|
leetcode-hot-100-20230928
https://thewangyang.github.io/2023/09/29/leetcode-hot-100-20230929/