1  public List<List<String>> printTree(TreeNode root) {
2 ArrayList<List<String>> al = new ArrayList<>();
3 if (root == null) return al;
4 if (root.left == null && root.right == null) {
5 al.add(new ArrayList<>());
6 al.get(0).add(String.valueOf(root.val));
7 return al;
8 }
9
10 int high = dep(root, 1);
11 String[][] ans = new String[(int) Math.pow(2, high)][high + 1];
12 add(root, (int) Math.pow(2, high - 1), 1, (int) Math.pow(2, high - 2), ans);
13 for (int i = 1; i <= high; i++) {
14 al.add(new ArrayList<>());
15 for (int j = 1; j < ans.length; j++)
16 al.get(i - 1).add(ans[j][i] == null ? "" : ans[j][i]);
17 }
18 return al;
19 }
20
21 public void add(TreeNode cur, int x, int y, int diff, String[][] ans) {
22 if (cur == null) return;
23 ans[x][y] = cur.val + "";
24 add(cur.left, x - diff, y + 1, diff / 2, ans);
25 add(cur.right, x + diff, y + 1, diff / 2, ans);
26 }
27
28
29 public int dep(TreeNode cur, int dep) {
30 if (cur == null) return dep - 1;
31 return Math.max(dep(cur.left, dep + 1), dep(cur.right, dep + 1));
32 }

最新文章

  1. 开源:ASP.NET Aries 开发框架
  2. MongoDB下载安装与简单增删改查
  3. 理解DOM事件流的三个阶段
  4. 【krpano】krpano xml资源解密(破解)软件说明与下载(v1.2)
  5. java之DatagramSocket、DatagramPackage丶MulticastSocket 广播学习
  6. vim does not map customized key?
  7. Spring中@Controller和@RestController之间的区别
  8. appium获取android app的包名和主Activity
  9. java基础知识回顾之java Thread类学习(九)--wait和notify区别
  10. POJ2676Sudoku
  11. delphi中的各种文件类型介绍
  12. Python之函数知识
  13. Cocos2D中Node的userObject实例变量使用时一个要注意的地方
  14. Qualcomm平台camera调试移植入门
  15. javascript基础之对象
  16. VMware 中安装虚拟机和宿主机通信
  17. grep简单用法
  18. xshell连接linux,切换焦点,自动执行ctrl+c
  19. Python爬虫基础(一)urllib2库的基本使用
  20. hash 冲突及解决办法。

热门文章

  1. js获取的 后端的列表。
  2. CentOS7 搭建 PXE 安装系统
  3. CentOS Linux release 7.6 zabbix5.0 安装
  4. ubuntu18.04 安装cython_bbox
  5. 微积分 II 笔记
  6. react项目--路由封装
  7. Kubernetes--管理资源标签(标签)
  8. 【RTOS】RTOS汇编入门 (1)
  9. Jmeter学习:时间类函数
  10. TCP通信实现两个主机之间的信息交互