/** * File: tree_node.dart * Created Time: 2023-2-12 * Author: Jefferson (JeffersonHuang77@gmail.com) */ /* 二元樹節點類別 */ class TreeNode { int val; // 節點值 int height; // 節點高度 TreeNode? left; // 左子節點引用 TreeNode? right; // 右子節點引用 /* 建構子 */ TreeNode(this.val, [this.height = 0, this.left, this.right]); } /* 將串列反序列化為二元樹:遞迴 */ TreeNode? listToTreeDFS(List arr, int i) { if (i < 0 || i >= arr.length || arr[i] == null) { return null; } TreeNode? root = TreeNode(arr[i]!); root.left = listToTreeDFS(arr, 2 * i + 1); root.right = listToTreeDFS(arr, 2 * i + 2); return root; } /* 將串列反序列化為二元樹 */ TreeNode? listToTree(List arr) { return listToTreeDFS(arr, 0); } /* 將二元樹序列化為串列:遞迴 */ void treeToListDFS(TreeNode? root, int i, List res) { if (root == null) return; while (i >= res.length) { res.add(null); } res[i] = root.val; treeToListDFS(root.left, 2 * i + 1, res); treeToListDFS(root.right, 2 * i + 2, res); } /* 將二元樹序列化為串列 */ List treeToList(TreeNode? root) { List res = []; treeToListDFS(root, 0, res); return res; }