leetcode 655. 输出二叉树 【时间击败100.00%】 【内存击败96.49%】
2024-10-20 05:42:09
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 }
最新文章
- 开源:ASP.NET Aries 开发框架
- MongoDB下载安装与简单增删改查
- 理解DOM事件流的三个阶段
- 【krpano】krpano xml资源解密(破解)软件说明与下载(v1.2)
- java之DatagramSocket、DatagramPackage丶MulticastSocket 广播学习
- vim does not map customized key?
- Spring中@Controller和@RestController之间的区别
- appium获取android app的包名和主Activity
- java基础知识回顾之java Thread类学习(九)--wait和notify区别
- POJ2676Sudoku
- delphi中的各种文件类型介绍
- Python之函数知识
- Cocos2D中Node的userObject实例变量使用时一个要注意的地方
- Qualcomm平台camera调试移植入门
- javascript基础之对象
- VMware 中安装虚拟机和宿主机通信
- grep简单用法
- xshell连接linux,切换焦点,自动执行ctrl+c
- Python爬虫基础(一)urllib2库的基本使用
- hash 冲突及解决办法。