本文實(shí)例講述了Python實(shí)現(xiàn)重建二叉樹的三種方法。分享給大家供大家參考,具體如下:
學(xué)習(xí)算法中,探尋重建二叉樹的方法:
如果懶得去看后面的內(nèi)容,可以直接點(diǎn)擊此處本站下載完整實(shí)例代碼。
思路
學(xué)習(xí)算法中,python 算法方面的資料相對較少,二叉樹解析重建更少,只能摸著石頭過河。
通過不同方式遍歷二叉樹,可以得出不同節(jié)點(diǎn)的排序。那么,在已知節(jié)點(diǎn)排序的前提下,通過某種遍歷方式,可以將排序進(jìn)行解析,從而構(gòu)建二叉樹。
應(yīng)用上來將,可以用來解析多項(xiàng)式、可以解析網(wǎng)頁、xml等。
本文采用前序遍歷方式的排列,對已知字符串進(jìn)行解析,并生成二叉樹。新手,以解題為目的,暫未優(yōu)化,未能體現(xiàn) Python 簡潔、優(yōu)美。請大牛不吝指正。
首先采用 input 輸入
節(jié)點(diǎn)類
class treeNode: def __init__(self, rootObj = None, leftChild = None, rightChild = None): self.key = rootObj self.leftChild = None self.rightChild = None
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。