1. 程式人生 > >【LeetCode 簡單題】89-左葉子之和

【LeetCode 簡單題】89-左葉子之和

宣告:

今天是第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