亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python二叉樹類以及其4種遍歷方法實(shí)例

 更新時(shí)間:2022年05月27日 11:24:52   作者:Hann?Yang  
二叉樹是一種特殊的樹,最直觀地體現(xiàn)于它的每個(gè)節(jié)點(diǎn)至多有兩個(gè)子節(jié)點(diǎn),二叉樹是非常實(shí)用的一種數(shù)據(jù)結(jié)構(gòu),常常用于實(shí)現(xiàn)二叉查找樹及二叉堆等,下面這篇文章主要給大家介紹了關(guān)于python二叉樹類以及其4種遍歷方法的相關(guān)資料,需要的朋友可以參考下

前言

之前學(xué)習(xí)過binarytree第三方庫,了解了它定義的各種基本用法。

昨天在問答頻道中做題時(shí)碰到一個(gè)關(guān)于二叉樹的算法填空題,感覺代碼不錯(cuò)非常值得學(xué)習(xí),于是整理代碼分享如下:

實(shí)例代碼:

from collections import deque  #層遍歷中用到隊(duì)列數(shù)據(jù)類型
 
class BTNode:   #二叉鏈中結(jié)點(diǎn)類
    def __init__(self,d = None):
        self.data = d       #結(jié)點(diǎn)值
        self.lchild = None  #左hai子指針
        self.rchild = None  #右hai子指針
 
class BTree: #二叉樹類
    def __init__(self,d = None):
        self.b = None       #根結(jié)點(diǎn)指針
    
    def DispBTree(self):    #返回二叉鏈的括號表示串
        return self._DispBTree1(self.b)
     
    def _DispBTree1(self,t):    #被DispBTree方法調(diào)用
        if t==None:             #空樹返回空串
            return ""
        else:
            bstr = t.data       #輸出根結(jié)點(diǎn)值
            if t.lchild != None or t.rchild != None:
                bstr += "("     #有hai子結(jié)點(diǎn)時(shí)輸出"("
                bstr += self._DispBTree1(t.lchild)    #遞歸輸出左子樹
            if t.rchild != None:
                bstr += ","     #有右hai子結(jié)點(diǎn)時(shí)輸出","
                bstr += self._DispBTree1(t.rchild)    #遞歸輸出右子樹
                bstr += ")"     #輸出")"
        return bstr
     
    def FindNode(self,x):       #查找值為x的結(jié)點(diǎn)算法
        return self._FindNode1(self.b,x)
     
    def _FindNode1(self,t,x):   #被FindNode方法調(diào)用
        if t==None: 
            return None         #t為空時(shí)返回null
        elif t.data==x: 
            return t            #t所指結(jié)點(diǎn)值為x時(shí)返回t
        else:
            p = self._FindNode1(t.lchild,x)    #在左子樹中查找
        if p != None: 
            return p            #在左子樹中找到p結(jié)點(diǎn),返回p
        else:
            return self._FindNode1(t.rchild,x)  #返回在右子樹中查找結(jié)果
         
    def Height(self):           #求二叉樹高度的算法
        return self._Height1(self.b)
         
    def _Height1(self,t):       #被Height方法調(diào)用
        if t==None:
            return 0            #空樹的高度為0
        else:
            lh = self._Height1(t.lchild)    #求左子樹高度lchildh
            rh = self._Height1(t.rchild)    #求右子樹高度rchildh
        return max(lh,rh)+1
 
def PreOrder(bt):   #先序遍歷的遞歸算法
    _PreOrder(bt.b)
    
def _PreOrder(t):   #被PreOrder方法調(diào)用
    if t != None:
        print(t.data,end = ' ')     #訪問根結(jié)點(diǎn)
        _PreOrder(t.lchild)         #先序遍歷左子樹
        _PreOrder(t.rchild)         #先序遍歷右子樹
    
def InOrder(bt):    #中序遍歷的遞歸算法
    _InOrder(bt.b)
    
def _InOrder(t):    #被InOrder方法調(diào)用
    if t != None:
        _InOrder(t.lchild)          #中序遍歷左子樹
        print(t.data,end = ' ')     #訪問根結(jié)點(diǎn)
        _InOrder(t.rchild)          #中序遍歷右子樹
    
def PostOrder(bt):  #后序遍歷的遞歸算法
    _PostOrder(bt.b)
    
def _PostOrder(t):  #被PostOrder方法調(diào)用
    if t != None:
        _PostOrder(t.lchild)        #后序遍歷左子樹
        _PostOrder(t.rchild)        #后序遍歷右子樹
        print(t.data,end = ' ')     #訪問根結(jié)點(diǎn)
 
def LevelOrder(bt): #層序遍歷的算法
    qu = deque()            #將雙端隊(duì)列作為普通隊(duì)列qu
    qu.append(bt.b)         #根結(jié)點(diǎn)進(jìn)隊(duì)
    while len(qu)>0:        #隊(duì)不空循環(huán)
        p = qu.popleft()            #出隊(duì)一個(gè)結(jié)點(diǎn)
        print(p.data,end = ' ')     #訪問p結(jié)點(diǎn)
        if p.lchild != None:        #有左hai子時(shí)將其進(jìn)隊(duì)
            qu.append(p.lchild)
        if p.rchild != None:        #有右hai子時(shí)將其進(jìn)隊(duì)
            qu.append(p.rchild)
 
def CreateBTree2(posts,ins):        #由后序序列posts和中序序列ins構(gòu)造二叉鏈
    bt = BTree()
    bt.b = _CreateBTree2(posts,0,ins,0,len(posts))
    return bt
 
def _CreateBTree2(posts,i,ins,j,n):
    if n <= 0:
        return None
    d = posts[i+n-1]        #取后序序列尾元素d
    t = BTNode(d)           #創(chuàng)建根結(jié)點(diǎn)(結(jié)點(diǎn)值為d)
    p = ins.index(d)        #在ins中找到根結(jié)點(diǎn)的索引
    k = p-j                 #確定左子樹中結(jié)點(diǎn)個(gè)數(shù)k
    t.lchild = _CreateBTree2(posts,i,ins,j,k)           #遞歸構(gòu)造左子樹
    t.rchild = _CreateBTree2(posts,i+k,ins,p+1,n-k-1)   #遞歸構(gòu)造右子樹
    return t
 
if __name__ == '__main__':
 
    inlst = ['D','G','B','A','E','C','F']
    posts = ['G','D','B','E','F','C','A']
 
    print(f"中序列表 :{inlst}")
    print(f"后序列表 :{posts}")
    
    #構(gòu)造二叉樹bt    
    bt = BTree()
    bt = CreateBTree2(posts,inlst)
    print(f"\n構(gòu)造二叉樹:{bt.DispBTree()}")
 
    x = 'F'
    if bt.FindNode(x):
        print(f"bt中存在 :'{x}'")
    else:
        print(f"bt中不存在 :'{x}'")
     
    print(f"bt的高度 :{bt.Height():^3}")
 
    print("\n先序遍歷 :",end='')
    PreOrder(bt)
    print("\n中序遍歷列 :",end='')
    InOrder(bt)
    print("\n后序遍歷 :",end='')
    PostOrder(bt)
    print("\n層序遍歷 :",end='')
    LevelOrder(bt)

中序列表:['D', 'G', 'B', 'A', 'E', 'C', 'F']
后序列表:['G', 'D', 'B', 'E', 'F', 'C', 'A']

構(gòu)造二叉樹:A(B(D(,G),C(E,F))
bt中存在 :'F'
bt的高度 : 4 

先序遍歷 :A B D G C E F 
中序遍歷 :D G B A E C F 
后序遍歷 :G D B E F C A 
層序遍歷 :A B C D E F G 

相關(guān)閱讀內(nèi)容:

總結(jié)

到此這篇關(guān)于python二叉樹類以及其4種遍歷方法的文章就介紹到這了,更多相關(guān)python二叉樹類遍歷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python常見的占位符總結(jié)及用法

    python常見的占位符總結(jié)及用法

    在本篇文章里小編給大家整理的是一篇關(guān)于python常見的占位符總結(jié)及用法,有興趣的朋友們可以跟著學(xué)習(xí)參考下。
    2021-07-07
  • python機(jī)器學(xué)習(xí)GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理解析

    python機(jī)器學(xué)習(xí)GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理解析

    這篇文章主要為大家介紹了GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理及代碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python獲取網(wǎng)絡(luò)圖片和視頻的示例代碼

    Python獲取網(wǎng)絡(luò)圖片和視頻的示例代碼

    Python 是一種多用途語言,廣泛用于腳本編寫。我們可以編寫Python 腳本來自動化日常事務(wù)。本文將用Python實(shí)現(xiàn)獲取Google圖片和YouTube視頻,需要的可以參考一下
    2022-03-03
  • 在win10和linux上分別安裝Python虛擬環(huán)境的方法步驟

    在win10和linux上分別安裝Python虛擬環(huán)境的方法步驟

    這篇文章主要介紹了在win10和linux上分別安裝Python虛擬環(huán)境的方法步驟,虛機(jī)環(huán)境有非常多的優(yōu)點(diǎn),今天我們用的虛擬環(huán)境是virtualenv。感興趣的小伙伴們可以參考一下
    2019-05-05
  • python中遍歷文件的3個(gè)方法

    python中遍歷文件的3個(gè)方法

    這篇文章主要介紹了python中遍歷文件的3個(gè)方法,本文分別使用os.path.walk()、os.walk()、os.listdir()來實(shí)現(xiàn),需要的朋友可以參考下
    2014-09-09
  • python自動查詢12306余票并發(fā)送郵箱提醒腳本

    python自動查詢12306余票并發(fā)送郵箱提醒腳本

    這篇文章主要為大家詳細(xì)介紹了Python自動查詢12306余票并發(fā)送郵箱提醒腳本,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Python自動化測試pytest中fixtureAPI簡單說明

    Python自動化測試pytest中fixtureAPI簡單說明

    這篇文章主要為大家介紹了Python自動化測試pytest中fixtureAPI的簡單說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10
  • Python中的Descriptor描述符學(xué)習(xí)教程

    Python中的Descriptor描述符學(xué)習(xí)教程

    簡單來說,數(shù)據(jù)描述符是指實(shí)現(xiàn)了__get__、__set__、__del__方法的類屬性,等效于定義了三個(gè)方法的接口,下面就來詳細(xì)看一下Python中的Descriptor修飾符學(xué)習(xí)教程
    2016-06-06
  • 簡單了解python的一些位運(yùn)算技巧

    簡單了解python的一些位運(yùn)算技巧

    這篇文章主要介紹了簡單了解python的一些位運(yùn)算技巧,位運(yùn)算的性能大家想必是清楚的,效率絕對高。相信愛好源碼的同學(xué),在學(xué)習(xí)閱讀源碼的過程中會發(fā)現(xiàn)不少源碼使用了位運(yùn)算,需要的朋友可以參考下
    2019-07-07
  • DjangoRestFramework 使用 simpleJWT 登陸認(rèn)證完整記錄

    DjangoRestFramework 使用 simpleJWT 登陸認(rèn)證完整記錄

    Djangorestframework-simplejwt是Django REST Framework框架的一個(gè)jwt插件,使用 python http 工具進(jìn)行接口測試的方法文中給大家提到,重點(diǎn)給大家分享djangorestframework-simplejwt 使用記錄及登陸認(rèn)證的完成過程,感興趣的朋友跟隨小編一起看看吧
    2021-06-06

最新評論