Leetcode 1448.统计二叉树中好节点的数目
1 题目描述(Leetcode题目链接)
给你一棵根为 root 的二叉树,请你返回二叉树中好节点的数目。
「好节点」X 定义为:从根到该节点 X 所经过的节点中,没有任何节点的值大于 X 的值。
输入:root = [3,1,4,3,null,1,5]
输出:4
解释:图中蓝色节点为好节点。
根节点 (3) 永远是个好节点。
节点 4 -> (3,4) 是路径中的最大值。
节点 5 -> (3,4,5) 是路径中的最大值。
节点 3 -> (3,1,3) 是路径中的最大值。
提示:
- 二叉树中节点数目范围是 [ 1 , 1 0 5 ] [1, 10^5] [1,105] 。
- 每个节点权值的范围是 [ − 1 0 4 , 1 0 4 ] [-10^4, 10^4] [−104,104] 。
2 题解
递归实现,记录每条路径的最大节点。
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def goodNodes(self, root: TreeNode) -> int:
self.res = 0
def goodguys(root, val):
if not root:
return
if root.val >= val:
self.res += 1
val = root.val
goodguys(root.left, val)
goodguys(root.right, val)
goodguys(root, float("-inf"))
return self.res