树的打印(Python)

这篇博客展示了如何利用Python的math模块计算树的深度和宽度,进而实现二叉树的两种不同方式的可视化打印。代码中定义了两个函数`print_tree`,分别通过空格对齐和居中对齐的方式展示树结构,适用于数据范围在10到20之间的列表。这两个方法有助于理解二叉树的结构和遍历方式。
摘要由CSDN通过智能技术生成

import math

def print_tree(lis: list, unit_width=2):
    n = len(lis) - 1

    depth = math.ceil(math.log2(n + 1))
    width = 2 ** depth - 1
    index = 1
    for i in range(depth):
        width //= 2  # 7
        pre = " " * (2 ** (4 - i) - 1) * unit_width
        tree_str = lis[index:index + 2 ** i]
        print(" " * width * unit_width, end="")
        print(pre.join(map(lambda x: "{:{}}".format(x, unit_width), tree_str)))
        index = index + 2 ** i

# 使用居中的方法打印
import math

'''
1.树深度公式
2.宽度=当前深度的满二叉树的所有节和叶的和
3.每个数的宽度
'''

lis = list(range(10, 20))
print(lis)


def print_tree(lis: list, unit_width=2):
    n = len(lis) - 1
    # 深度
    depth = math.ceil(math.log2(n + 1))
    width = 2 ** depth - 1
    index = 1
    for i in range(depth):
        for j in range(2 ** (i)):
            tree_str = "{:^{}}".format(lis[index], width * unit_width)
            print(tree_str, end=" " * unit_width)
            index += 1
            if index > n:
                break
        width //= 2
        print()


w = print_tree(lis)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时越zz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值