题目:
给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。
题解:
1.递归
需要创建List<List<Integer>>,里面的list分别是每层的。
/**
* 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 {
List<List<Integer>> resList = new ArrayList<>();
public List<List<Integer>> levelOrder(TreeNode root) {
check(root, 0);
return resList;
}
public void check(TreeNode node, int deep) { //deep表示此刻node的深度
if (node == null) {
return;
}
deep++; //进一层深度加1
if (resList.size() < deep) {
List<Integer> list = new ArrayList<>();
resList.add(list);
}
resList.get(deep - 1).add(node.val); //将node的值添加到对应深度的list
check(node.left, deep);
check(node.right, deep);
}
}
参考:代码随想录