041-Python语言开发PythonComputation(十 一)

 

Python语言开发PythonComputation(十一)

Python语言开发PythonComputation(十一)

 

 

 

二叉树

 

自己写了一个简单的二叉树

import random


class Node():
    def __init__(self, num):
        self.num = num
        self.parent = 'xx'
        self.left_node = 'xx'
        self.right_node = 'xx'

    def __str__(self):
        return str(self.num)

    def handle_node(self, node):
        if node.num > self.num:
            if self.right_node == 'xx':
                self.right_node = node
                node.parent = self
            else:
                self.right_node.handle_node(node)
        else:
            if self.left_node == 'xx':
                self.left_node = node
                node.parent = self
            else:
                self.left_node.handle_node(node)


class Tree():

    def __init__(self):
        node = Node(50)
        self.list = [node]

    def add(self, node):
        self.list.append(node)

        if node.num in self.list:
            pass

        mother = self.list[0]
        mother.handle_node(node)

    def __str__(self):
        result = ''
        for i in self.list:
            result = result + str(i) + ','
        return result


tree = Tree()

for i in range(10):
    randint = random.randint(1, 100)
    node = Node(randint)
    tree.add(node)
    print('---{}'.format(node.parent))
    if node.num < node.parent.num:
        print(node.num)
    else:
        print('------{}'.format(node.num))

    print('==========')

 

 

这是第一次写二叉树

挺有意思

 

 

再强化一下打印

import random


class Node():
    def __init__(self, num):
        self.num = num
        self.parent = 'xx'
        self.left_node = 'xx'
        self.right_node = 'xx'

    def __str__(self):
        return str(self.num)

    def handle_node(self, node):
        if node.num > self.num:
            if self.right_node == 'xx':
                self.right_node = node
                node.parent = self
            else:
                self.right_node.handle_node(node)
        else:
            if self.left_node == 'xx':
                self.left_node = node
                node.parent = self
            else:
                self.left_node.handle_node(node)
    def printNode(self):
        print('---{}'.format(self.num))
        print('{}---{}'.format(self.left_node,self.right_node))
        print('==============')
        if self.left_node!='xx':
            self.left_node.printNode()
        if self.right_node!='xx':
            self.right_node.printNode()

class Tree():

    def __init__(self):
        node = Node(50)
        self.list = [node]

    def add(self, node):
        if node.num in self.list:
            return

        self.list.append(node)
        mother = self.list[0]
        mother.handle_node(node)

    def __str__(self):
        result = ''
        for i in self.list:
            result = result + str(i) + ','
        return result


def printTree(tree):
    tree.list[0].printNode()

tree = Tree()
for i in range(10):
    randint = random.randint(1, 100)
    node = Node(randint)
    tree.add(node)
    print('---{}'.format(node.parent))
    if node.num < node.parent.num:
        print(node.num)
    else:
        print('------{}'.format(node.num))

    print('==========')

printTree(tree)

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值