如何在Python中創(chuàng)建二叉樹(shù)
前言
本文的內(nèi)容是數(shù)據(jù)結(jié)構(gòu)中二叉樹(shù)部分最基礎(chǔ)的,之所以寫(xiě)一下主要是為了方便刷題的時(shí)候,能夠在自己電腦上很快的使用這種小的demo進(jìn)行復(fù)雜的練習(xí)。
二叉樹(shù)節(jié)點(diǎn)定義
二叉樹(shù)的節(jié)點(diǎn)定義如下:
class TreeNode():#二叉樹(shù)節(jié)點(diǎn) def __init__(self,val,lchild=None,rchild=None): self.val=val #二叉樹(shù)的節(jié)點(diǎn)值 self.lchild=lchild #左孩子 self.rchild=rchild #右孩子
遞歸構(gòu)建二叉樹(shù)
本文使用的前序遞歸構(gòu)建的方法(其余順序讀者自行變化,本文主要意在如何快速構(gòu)建能夠執(zhí)行的二叉樹(shù))
例如,我們想構(gòu)建一個(gè)如下圖所示的樹(shù)(其前序遍歷結(jié)果為:abcde):
這里我們需要使用到擴(kuò)展的二叉樹(shù),也就是要告訴計(jì)算機(jī)什么是葉結(jié)點(diǎn),什么是空節(jié)點(diǎn),否側(cè)無(wú)法分辨左右節(jié)點(diǎn)。例如先序遍歷的順序?yàn)?abcde",擴(kuò)展的二叉樹(shù)前序序列為:“abc##d##e##”,#代表此處節(jié)點(diǎn)為None,如下圖:
既然是使用遞歸的方法構(gòu)建二叉樹(shù),主要需要理解遞歸的過(guò)程,這種思路將在之后的很多地方用的到。
要知道如何遞歸的構(gòu)建二叉樹(shù),我們不能糾結(jié)于遞歸每一層到底干了什么,這樣就會(huì)一直糾結(jié)下去(所有的遞歸問(wèn)題都一樣)。我們需要注意的是:
- 在我們的任務(wù)中,終止條件是什么?
- 在我們的任務(wù)中,本次遞歸要干嘛?
- 在我們的任務(wù)中,本次遞歸要返回給上一次遞歸的是啥?
在遞歸構(gòu)建二叉樹(shù)的任務(wù)中,我們要做到不糾結(jié)于每一層,而是只關(guān)注該層在做什么,這樣,對(duì)于下圖左側(cè)的樹(shù),我們就可以看作為右側(cè)的樹(shù),它只有自己a (a),左子樹(shù)B (bcd)和右子樹(shù)C (e)。
這樣我們需要注意的那三個(gè)問(wèn)題的回答自然就有了(做遞歸問(wèn)題,心中要想著怎么回答這三個(gè)問(wèn)題):
- 在我們的任務(wù)中,終止條件是什么?
[給我們的字符用完,也就不需要再創(chuàng)建節(jié)點(diǎn)了]
- 在我們的任務(wù)中,本次遞歸要干嘛?
[本次遞歸要?jiǎng)?chuàng)建三個(gè)節(jié)點(diǎn),一個(gè)根節(jié)點(diǎn),一個(gè)左節(jié)點(diǎn),一個(gè)右節(jié)點(diǎn)]
- 在我們的任務(wù)中,本次遞歸要返回給上一次遞歸的是啥?
[當(dāng)然是返回一個(gè)本層構(gòu)造好的樹(shù)的根節(jié)點(diǎn)]
理解了上述三個(gè)問(wèn)題的回答,遞歸的代碼自然可以寫(xiě)出:
def Creat_Tree(Root,val): if len(vals)==0:#終止條件:val用完了 return Root if vals[0]!='#':#本層需要干的就是構(gòu)建Root、Root.lchild、Root.rchild三個(gè)節(jié)點(diǎn)。 Root = TreeNode(vals[0]) vals.pop(0) Root.lchild = Creat_Tree(Root.lchild,val) Root.rchild = Creat_Tree(Root.rchild,val) return Root#本次遞歸要返回給上一次的本層構(gòu)造好的樹(shù)的根節(jié)點(diǎn) else: Root=None vals.pop(0) return Root#本次遞歸要返回給上一次的本層構(gòu)造好的樹(shù)的根節(jié)點(diǎn)
看懂了上述內(nèi)容,構(gòu)建一棵我們想象的二叉樹(shù)就很簡(jiǎn)單了,只要輸入一個(gè)我們心目中前序遍歷擴(kuò)展的二叉樹(shù)序列即可:
if __name__ == '__main__': Root = None strs="abc##d##e##"#前序遍歷擴(kuò)展的二叉樹(shù)序列 vals = list(strs) Roots=Creat_Tree(Root,vals)#Roots就是我們要的二叉樹(shù)的根節(jié)點(diǎn)。
以上就是如何在Python中創(chuàng)建二叉樹(shù)的詳細(xì)內(nèi)容,更多關(guān)于Python創(chuàng)建二叉樹(shù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Python對(duì)稱的二叉樹(shù)多種思路實(shí)現(xiàn)方法
- python3實(shí)現(xiàn)在二叉樹(shù)中找出和為某一值的所有路徑(推薦)
- Python實(shí)現(xiàn)二叉樹(shù)的最小深度的兩種方法
- Python3 翻轉(zhuǎn)二叉樹(shù)的實(shí)現(xiàn)
- Python3實(shí)現(xiàn)二叉樹(shù)的最大深度
- Python3 合并二叉樹(shù)的實(shí)現(xiàn)
- 用Python實(shí)現(xiàn)二叉樹(shù)、二叉樹(shù)非遞歸遍歷及繪制的例子
- 基于python二叉樹(shù)的構(gòu)造和打印例子
- Python 二叉樹(shù)的層序建立與三種遍歷實(shí)現(xiàn)詳解
- python3實(shí)現(xiàn)二叉樹(shù)的遍歷與遞歸算法解析(小結(jié))
相關(guān)文章
使用Python的Twisted框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的服務(wù)器
這篇文章主要介紹了使用Python的Twisted框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的服務(wù)器,翻譯自Twisted的文檔,需要的朋友可以參考下2015-04-04基于Python的身份證號(hào)碼自動(dòng)生成程序
今天收到一個(gè)小需求:需要一個(gè)自動(dòng)生成身份證號(hào)碼的小程序。近期用python較多,因此打算用python實(shí)現(xiàn)2014-08-08python虛擬機(jī)pyc文件結(jié)構(gòu)的深入理解
這篇文章主要為大家介紹了python虛擬機(jī)之pyc文件結(jié)構(gòu)的深入探究理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03Python中l(wèi)ist列表的賦值方法及遇到問(wèn)題處理
這篇文章主要介紹了Python中l(wèi)ist列表的賦值方法及遇到問(wèn)題處理,記錄在列表list的賦值過(guò)程中遇到的問(wèn)題,并對(duì)列表的拷貝相關(guān)知識(shí)進(jìn)行匯總,需要的朋友可以參考一下2022-03-03python解決方案:WindowsError: [Error 2]
使用Python的rename()函數(shù)重命名文件時(shí)出現(xiàn)問(wèn)題,提示 WindowsError: [Error 2] 錯(cuò)誤,需要的朋友可以參考下2016-08-08python代碼實(shí)現(xiàn)TSNE降維數(shù)據(jù)可視化教程
今天小編就為大家分享一篇python代碼實(shí)現(xiàn)TSNE降維數(shù)據(jù)可視化教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02Python基礎(chǔ) 括號(hào)()[]{}的詳解
這篇文章主要介紹了Python基礎(chǔ) 括號(hào)()、[]、{},下面文章將圍繞這三個(gè)括號(hào)的相關(guān)解析展開(kāi)內(nèi)容,需要的朋友可以參考一下,洗碗粉對(duì)你有所幫助2021-11-11numpy創(chuàng)建單位矩陣和對(duì)角矩陣的實(shí)例
今天小編就為大家分享一篇numpy創(chuàng)建單位矩陣和對(duì)角矩陣的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11