【LeetCode 簡單題】89-左葉子之和
阿新 • • 發佈:2018-11-19
宣告:
今天是第89道題。計算給定二叉樹的所有左葉子之和。以下所有程式碼經過樓主驗證都能在LeetCode上執行成功,程式碼也是借鑑別人的,在文末會附上參考的部落格連結,如果侵犯了博主的相關權益,請聯絡我刪除
(手動比心ღ( ´・ᴗ・` ))
正文
題目:計算給定二叉樹的所有左葉子之和。
示例:
3 / \ 9 20 / \ 15 7 在這個二叉樹中,有兩個左葉子,分別是 9 和 15,所以返回 24
解法1。用遞迴做法,不斷找到左子節點,用一個sum記錄和,程式碼如下。
執行用時: 32 ms, 在Sum of Left Leaves的Python提交中擊敗了49.00% 的使用者
# Definition for a binary tree node. # class TreeNode(object): # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Solution(object): def sumOfLeftLeaves(self, root): """ :type root: TreeNode :rtype: int """ if not root: return 0 sum = 0 if root.left and not root.left.left and not root.left.right: sum += root.left.val sum += self.sumOfLeftLeaves(root.left) sum += self.sumOfLeftLeaves(root.right) return sum
解法2。迭代的方法,程式碼如下。
執行用時: 40 ms, 在Sum of Left Leaves的Python提交中擊敗了10.44% 的使用者
# Definition for a binary tree node. # class TreeNode(object): # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Solution(object): def sumOfLeftLeaves(self, root): """ :type root: TreeNode :rtype: int """ nodes = [] nodes.append(i) sum = 0 while nodes: cur = nodes.pop() if cur.left: if not cur.left.left and not cur.left.right: sum += cur.left.val else: nodes.append(cur.left) if cur.right: nodes.append(cur.right) return sum
結尾
解法1&解法2:https://blog.csdn.net/qiubingcsdn/article/details/83029384