Python程序查找二叉树中所有节点的总和

Python程序查找二叉树中所有节点的总和

在需要查找树的所有节点的总和时,可以创建一个类并包含设置根节点,向树中添加元素,搜索特定元素,添加树元素以查找总和等方法。可以创建类的实例以访问和使用这些方法。

以下是相同操作的演示 –

更多Python相关文章,请阅读:Python 教程

例子

class Tree_struct:
    def __init__(self, data=None):
        self.key = data
        self.children = []

    def set_root(self, data):
        self.key = data

    def add_node(self, node):
        self.children.append(node)

    def search_node(self, key):
        if self.key == key:
            return self
        for child in self.children:
            temp = child.search_node(key)
            if temp is not None:
                return temp
        return None

    def sum_node(self):
        my_summation = self.key
        for child in self.children:
            my_summation = my_summation + child.sum_node()
        return my_summation

my_instance = None

print('菜单(假定没有重复的键)')
print('add <data> at root')
print('add <data> below <data>')
print('sum')
print('quit')

while True:
    my_input = input('您要执行什么操作?').split()

    operation = my_input[0].strip().lower()
    if operation == 'add':
        data = int(my_input[1])
        new_node = Tree_struct(data)
        suboperation = my_input[2].strip().lower()
        if suboperation == 'at':
            my_instance = new_node
        elif suboperation == 'below':
            position = my_input[3].strip().lower()
            key = int(position)
            ref_node = None
            if my_instance is not None:
                ref_node = my_instance.search_node(key)
            if ref_node is None:
                print('没有这个键')
                continue
            ref_node.add_node(new_node)

    elif operation == 'sum':
        if my_instance is None:
            print('树为空')
        else:
            my_summation = my_instance.sum_node()
            print('所有节点的总和为:{}'.format(my_summation))

    elif operation == 'quit':
        break

输出

菜单(假定没有重复的键)
add <data> at root
add <data> below <data>
sum
quit
您要执行什么操作?add 5 at root
您要执行什么操作?add 7 below 5
您要执行什么操作?add 0 below 7
您要执行什么操作?sum
所有节点的总和为:12
您要执行什么操作?quit

说明

  • 创建了“Tree_struct”类并具有所需的属性。

  • 它有一个“init”函数,用于创建一个空列表。

  • 定义了一个名为’set_root’的方法,它有助于设置二叉树的根值。

  • 它有一个“add_node”方法,它帮助将元素添加到树中。

  • 定义了一个名为’search_elem’的方法,它有助于搜索特定元素。

  • 定义了一个名为’sum_node’的方法,它有助于添加树元素并找到总和。

  • 创建了一个实例并分配给“None”。

  • 获取用户输入的执行操作。

  • 根据用户的选择,执行操作。

  • 在控制台上显示相关输出。

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程