国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

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

問題描述

’’’這是二叉樹的定義’’’class TreeNode: def __init__(self, val):self.val = valself.left, self.right = None, None’’’這是路徑函數’’’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)

這是我的代碼,但是每次都是打印全部節點。然后DEBUG發現,每次遞歸到右子樹,tmp數組會保留之前遍歷完左子樹的狀態,而根本不是我想的從根到右子樹的狀態。這是作用域的問題?可我找不到怎么解決,在此請求解答,謝謝

問題解答

回答1:

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

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都指向一塊內存 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)

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 免费女人18毛片a级毛片视频 | 久久精品成人一区二区三区 | 日韩a一级欧美一级 | 久久精品一区二区三区四区 | 免费一级欧美在线观看视频片 | 亚洲免费观看在线视频 | 欧美日韩亚洲在线观看 | videos性欧美| ccyycom草草影院成人91 | 国产欧美亚洲三区久在线观看 | 欧美成人精品一区二区三区 | 99久久精品免费看国产免费 | 成人网在线视频 | 美女黄页网站免费进入 | 欧美综合在线观看 | av毛片免费看 | 亚洲美女中文字幕 | 国产麻豆入在线观看 | 国产真实乱子伦精品视手机观看 | 欧美日韩一二区 | free性欧美嫩交 | 精品一区二区三区三区 | 看真人视频a级毛片 | 国产粗大猛烈18p | 美日韩黄色片 | 精品国产乱码久久久久久一区二区 | 欧美一级专区免费大片俄罗斯 | 国产萌白酱在线一区二区 | 爱视频福利广场 | 免费国产一区二区三区 | 国产乱纶 | 在线视频精品视频 | 免费欧洲毛片a级视频 | 日韩a毛片免费全部播放完整 | a级国产精品片在线观看 | 成人免费久久精品国产片久久影院 | 午夜在线视频一区二区三区 | 自拍 欧美 在线 综合 另类 | 免费人成黄页网站在线观看国产 | 国产欧美日韩一区二区三区在线 | 92av在线|