日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Python 二叉樹 層遍歷&輸出層數(shù)

系統(tǒng) 2450 0
            
              class BTNode(object):
    def __init__(self, key=None, lchild=None, rchild=None):
        self.key = key
        self.lchild = lchild
        self.rchild = rchild

class BiTree(object):
    def __init__(self, data_list):
        self.root = BTNode()
        self.queue = []  # 用于存放正在操作的子樹的三個(gè)節(jié)點(diǎn),依次是root, left, right
        
    def add(self, ele):
        new_node = BTNode(ele)
        self.queue.append(new_node)
        if self.root.key is None:
            self.root = new_node
        else:
            tree_node = self.queue[0]
            if tree_node.lchild is None:
                tree_node.lchild = new_node
            else:
                tree_node.rchild = new_node
                self.queue.pop(0)

    
    def preOrderTrave(self, bt):
        if bt is not None:
            print(bt.key, end=" ")
            self.preOrderTrave(bt.lchild)
            self.preOrderTrave(bt.rchild)
            
    def levelTrave(self, bt):
        if bt is not None:
            queue =[bt]
            level = 0
            while queue:
                print(level, "層:", end=":")
                for i in range(len(queue)):
                    bt = queue.pop(0)
                    print(bt.key, end=" ")
                    if bt.lchild != None:
                        queue.append(bt.lchild)
                    if bt.rchild != None:
                        queue.append(bt.rchild)
                level = level + 1
                print("\n")

btree = BiTree(data_list)
for i in range(20):
    btree.add(i)
        
btree.preOrderTrave(btree.root)
print("\n")
btree.levelTrave(btree.root)
            
          

?


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 陈巴尔虎旗| 定州市| 蕲春县| 黄浦区| 平南县| 甘洛县| 庆城县| 响水县| 仁怀市| 宣化县| 合阳县| 巫溪县| 泰州市| 乌鲁木齐市| 珠海市| 天津市| 漳浦县| 泾阳县| 黄陵县| 临海市| 桐城市| 丹棱县| 武威市| 海城市| 临邑县| 额敏县| 盐山县| 宝山区| 南京市| 南城县| 娄底市| 兴业县| 繁昌县| 嘉峪关市| 民和| 冕宁县| 鞍山市| 安西县| 德化县| 色达县| 枣庄市|