Python二叉樹(shù)的鏡像轉(zhuǎn)換實(shí)現(xiàn)方法示例
本文實(shí)例講述了Python二叉樹(shù)的鏡像轉(zhuǎn)換實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
問(wèn)題描述
操作給定的二叉樹(shù),將其變換為源二叉樹(shù)的鏡像。
思路描述
1. 代碼比文字更直觀(guān)
2. 文字描述:新建一個(gè)二叉樹(shù),利用遞歸法,將源二叉樹(shù)上的左節(jié)點(diǎn)賦值到新二叉樹(shù)的右節(jié)點(diǎn),將源二叉樹(shù)上的右節(jié)點(diǎn)賦值到新二叉樹(shù)的左節(jié)點(diǎn)。
Python代碼
# 方式1:生成新的鏡像二叉樹(shù) def getMirrorBST(self, root): if root == None: return newTree = treeNode(root.val) newTree.right = self.getMirrorBST(root.left) newTree.left = self.getMirrorBST(root.right) return newTree
但是提交代碼后,說(shuō)通過(guò)率為0… 原來(lái)要求將原有的二叉樹(shù)就地改成鏡像二叉樹(shù)…如此一來(lái),代碼就更簡(jiǎn)單了:因?yàn)榻粨Q根節(jié)點(diǎn)的左右子節(jié)點(diǎn)時(shí),以左右子節(jié)點(diǎn)為根節(jié)點(diǎn)的左子樹(shù)和右子樹(shù)也會(huì)交換位置。最終的Python代碼如下:
# 方式2:改變給定的二叉樹(shù)為鏡像二叉樹(shù) def turnToMirror(self, root): if root == None: return root.right, root.left = root.left, root.right self.turnToMirror(root.left) self.turnToMirror(root.right) return root
包含測(cè)試代碼的最終代碼如下:
class Solution: # 給定一個(gè)二叉樹(shù),獲得其鏡像(軸對(duì)稱(chēng))的鏡像二叉樹(shù): # 方式1:生成新的鏡像二叉樹(shù) def getMirrorBST(self, root): if root == None: return newTree = treeNode(root.val) newTree.right = self.getMirrorBST(root.left) newTree.left = self.getMirrorBST(root.right) return newTree # 方式2:改變給定的二叉樹(shù)為鏡像二叉樹(shù) def turnToMirror(self, root): if root == None: return root.right, root.left = root.left, root.right self.turnToMirror(root.left) self.turnToMirror(root.right) return root # 給定二叉樹(shù)的前序遍歷和中序遍歷,獲得該二叉樹(shù) def getBSTwithPreTin(self, pre, tin): if len(pre)==0 | len(tin)==0: return None root = treeNode(pre[0]) for order,item in enumerate(tin): if root .val == item: root.left = self.getBSTwithPreTin(pre[1:order+1], tin[:order]) root.right = self.getBSTwithPreTin(pre[order+1:], tin[order+1:]) return root class treeNode: def __init__(self, x): self.left = None self.right = None self.val = x if __name__ == '__main__': flag = "turnToMirror" solution = Solution() preorder_seq = [1, 2, 4, 7, 3, 5, 6, 8] middleorder_seq = [4, 7, 2, 1, 5, 3, 8, 6] treeRoot1 = solution.getBSTwithPreTin(preorder_seq, middleorder_seq) if flag == "mirrorBST": newRoot = solution.getMirrorBST(treeRoot1) print(newRoot) if flag == "turnToMirror": solution.turnToMirror(treeRoot1) print(treeRoot1)
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門(mén)與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Pycharm配置遠(yuǎn)程SSH服務(wù)器實(shí)現(xiàn)(切換不同虛擬環(huán)境)
本文主要介紹了Pycharm配置遠(yuǎn)程SSH服務(wù)器實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02Python實(shí)現(xiàn)Sqlite將字段當(dāng)做索引進(jìn)行查詢(xún)的方法
這篇文章主要介紹了Python實(shí)現(xiàn)Sqlite將字段當(dāng)做索引進(jìn)行查詢(xún)的方法,涉及Python針對(duì)sqlite數(shù)據(jù)庫(kù)索引操作的相關(guān)技巧,需要的朋友可以參考下2016-07-07python 捕獲shell腳本的輸出結(jié)果實(shí)例
下面小編就為大家?guī)?lái)一篇python 捕獲shell腳本的輸出結(jié)果實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01python網(wǎng)頁(yè)請(qǐng)求urllib2模塊簡(jiǎn)單封裝代碼
這篇文章主要分享一個(gè)python網(wǎng)頁(yè)請(qǐng)求模塊urllib2模塊的簡(jiǎn)單封裝代碼,有需要的朋友參考下2014-02-02如何使用Python對(duì)NetCDF數(shù)據(jù)做空間相關(guān)分析
這篇文章主要介紹了如何使用Python對(duì)NetCDF數(shù)據(jù)做空間相關(guān)分析,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-04-04numpy.random.choice()函數(shù)詳解
處理數(shù)據(jù)時(shí)我們經(jīng)常需要從數(shù)組中隨機(jī)抽取元素,這時(shí)候我們可以考慮使用np.random.choice()函數(shù),這篇文章主要介紹了numpy.random.choice()函數(shù),需要的朋友可以參考下2023-05-05python os.path.isfile()因參數(shù)問(wèn)題判斷錯(cuò)誤的解決
今天小編就為大家分享一篇python os.path.isfile()因參數(shù)問(wèn)題判斷錯(cuò)誤的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11django之狀態(tài)保持-使用redis存儲(chǔ)session的例子
今天小編就為大家分享一篇django之狀態(tài)保持-使用redis存儲(chǔ)session的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07