我和我的朋友正在做一个简单的 Python 项目。实际上,我们正在以自己的方式实现前缀并行求和算法。
我们正在创建和处理一个格式非常奇怪的二叉树。我们希望将此格式转换为 Tree 打印库/软件(如 ete2)所接受的格式。
因此,树的每一层都以这种方式推送到列表中
[ [level0], [level1], ... [level i-1], [root] ]
在我们的格式中,每个内部列表(树的级别)都有偶数个节点或叶子。
例如,假设我们有这个输入:[1, 2, 3, 4, 5]
. 这将产生以下输出列表:[[1, 2, 3, 4], [3, 7], [10, 5], [15]]
上述输出示例的问题是,有时叶子不在最后一级,但它们包含在上一级列表中。这使得很难处理列表列表并将节点与叶子区分开来并将它们安排在正确的位置。
我们希望将其可视化如下:
http://i.imgur.com/BKrqNZi.png
其中括号中的数字是节点,其他数字是叶子。
为了生成这个输出树,我们想使用一个 Tree 绘图库。他们中的大多数人都期望这种格式:[root, [left], [right]]
因此,在我们的示例中,我们的格式应该是这样的:
[15, [10, [3, [1], [2]], [7, [3], [4]] ], [5] ]
因为我们目前无法重写代码的整个逻辑,所以我们正在寻找一种巧妙的方法将我们奇怪的格式转换为那个格式。
欢迎任何想法。非常感谢您提前。