把二叉树打印成多行
Posted yihangzhou
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了把二叉树打印成多行相关的知识,希望对你有一定的参考价值。
题目描述
从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。
import java.util.ArrayList; /* public class TreeNode { int val = 0; TreeNode left = null; TreeNode right = null; public TreeNode(int val) { this.val = val; } } */ public class Solution { ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) { ArrayList<ArrayList<Integer>> list = new ArrayList<>(); depth(pRoot, 1, list); return list; } public void depth(TreeNode node, int depth, ArrayList<ArrayList<Integer>> list) { if(node == null) return; if(depth > list.size()) list.add(new ArrayList<Integer>()); list.get(depth-1).add(node.val); depth(node.left, depth + 1, list); depth(node.right, depth + 1, list); } }
以上是关于把二叉树打印成多行的主要内容,如果未能解决你的问题,请参考以下文章