午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

python怎么獲得二叉樹根到所有葉子的路徑?

瀏覽:217日期:2022-07-19 09:52:28

問題描述

’’’這是二叉樹的定義’’’class TreeNode: def __init__(self, val):self.val = valself.left, self.right = None, None’’’這是路徑函數(shù)’’’def dfs(node, result, tmp): if node == None:return tmp.append(node) if node.left == None and node.right == None:result.append([i.val for i in tmp])return dfs(node.left, result, tmp) dfs(node.right, result, tmp)

這是我的代碼,但是每次都是打印全部節(jié)點(diǎn)。然后DEBUG發(fā)現(xiàn),每次遞歸到右子樹,tmp數(shù)組會(huì)保留之前遍歷完左子樹的狀態(tài),而根本不是我想的從根到右子樹的狀態(tài)。這是作用域的問題?可我找不到怎么解決,在此請(qǐng)求解答,謝謝

問題解答

回答1:

是作用域的問題,你的算法大概沒有多少問題,主要是你要知道,給函數(shù)傳參的時(shí)候,尤其是傳入可變參數(shù)(你這里是列表)的時(shí)候,你要做到心中有數(shù)。這里你的問題主要集中在tmp上面,之所以會(huì)保留左子樹的狀態(tài),是因?yàn)槟阍诒闅v左子樹的時(shí)候,添加了左子樹到tmp中了,然后你又在下一次遞歸調(diào)用中把添加后的列表放到了列表中,如果只有左子樹,是沒問題的,如果有右子樹,就會(huì)出現(xiàn)問題。語言表達(dá)能力有限,我把改過的代碼貼出來給你看看

import copyclass TreeNode: def __init__(self, val):self.val = valself.left, self.right = None, Nonedef dfs(node, result, tmp=list()): if node is None:return tmp.append(node) # 這里需要用拷貝而不是用 = 賦值,也可以遍歷賦值 tmp1 = copy.deepcopy(tmp) if node.left is None and node.right is None:result.append([i.val for i in tmp])return if node.left is not None:dfs(node.left, result, tmp) # 遍歷右子樹需要帶上不同的變量,否則左子樹的tmp和右子樹的tmp都指向一塊內(nèi)存 if node.right is not None:dfs(node.right, result, tmp1)if __name__ == ’__main__’: node1 = TreeNode(’a’) node2 = TreeNode(’b’) node3 = TreeNode(’c’) node4 = TreeNode(’d’) node5 = TreeNode(’e’) node6 = TreeNode(’f’) node7 = TreeNode(’g’) node1.left = node2 node1.right = node3 node2.left = node4 node2.right = node5 node4.left = node6 node3.left = node7 r = [] dfs(node1, result=r) print(r)

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 日韩毛片在线免费观看 | 成人av片在线观看 | 欧美日韩一区在线观看 | 久久久久人 | 欧美一道本 | 国产精品久久久影院 | 国产免费看av | 亚洲第一页综合 | 超碰在线观看99 | 欧美国产一区二区三区 | 黄色片视频免费 | 免费精品在线 | 91午夜理伦私人影院 | 成人爱爱网站 | 欧美成人精品一区二区三区在线看 | 国产三级精品三级观看 | 人人狠狠| 日韩精品久久久久久 | 欧美一区久久 | 日韩精品中文字幕一区二区 | 亚洲精品视频一区二区三区 | zjzjzjzjzj亚洲女人 | 第一页在线观看 | 你懂的在线观看 | 成人区视频| 人人搞人人爽 | 青青国产精品 | 欧美放荡性医生videos | 97视频人人| 丰满白嫩尤物一区二区 | 91精品国产入口在线 | 粉色视频导航 | 亚洲精品伊人 | av在线播放网址 | 天天干天天曰 | 国产 欧美 精品 | 男生操女生免费网站 | 中文字幕视频免费 | 国产精品超碰 | 深夜小视频在线观看 | 在线免费a视频 |