题目:
给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。
示例 1:
输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]
示例 2:
输入:root = [1]
输出:[[1]]
思路:
1. 树的层次遍历可以一下子就想到使用队列来完成, 出1, 入改节点的左右节点
2. 此处由于每层节点分隔成不同list,又想到可以用递归来做, 使用上层得到下层,下层list为空时递归结束。
代码:
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;
}
}
public List<List<Integer>> levelOrder(TreeNode root) {
List<List<Integer>> result = new ArrayList<>();
if (root == null) {
return result;
}
sonOrder(Arrays.asList(root), result);
return result;
}
public void sonOrder(List<TreeNode> parent, List<List<Integer>> res) {
List<TreeNode> son = new ArrayList<>();
List<Integer> r = new ArrayList<>();
for (TreeNode node : parent) {
r.add(node.val);
if (node.left != null) {
son.add(node.left);
}
if (node.right != null) {
son.add(node.right);
}
}
res.add(r);
if (son.size() == 0) {
return;
}
else {
sonOrder(son, res);
}
}