一网友说公司部门裁员,把一个月薪一万五和一个月薪三万的裁掉了,并且把他们的工作都交给了该网友,该网友提出涨薪变成十恶不赦了。
三个人的活让一个人干,这谁能抗的住,如果真想让一个人干涨点工资也很正常,但是没通过,所有网友都劝他赶紧跑。
--------------下面是今天的算法题--------------
来看下今天的算法题,这题是LeetCode的第112题:路径总和。
问题描述
输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。
输入:root = [1,2,3], targetSum = 5
输出:false
解释:树中存在两条根节点到叶子节点的路径:
(1 --> 2): 和为 3
(1 --> 3): 和为 4
不存在 sum = 5 的根节点到叶子节点的路径。
树中节点的数目在范围 [0, 5000] 内
-1000 <= Node.val <= 1000
-1000 <= targetSum <= 1000
问题分析
public boolean hasPathSum(TreeNode root, int targetSum) {
if (root == null)
return false;
// 如果到叶子节点了,并且剩余值等于叶子节点的值,返回true。
if (root.left == null && root.right == null && targetSum == root.val)
return true;
// 分别沿着左右子节点走下去,然后顺便把当前节点的值减掉,
// 左右子节点只要有一个返回true,说明存在这样的结果。
return hasPathSum(root.left, targetSum - root.val)
|| hasPathSum(root.right, targetSum - root.val);
}
public:
bool hasPathSum(TreeNode *root, int targetSum) {
if (root == nullptr)
return false;
// 如果到叶子节点了,并且剩余值等于叶子节点的值,返回true。
if (root->left == nullptr && root->right == nullptr && targetSum == root->val)
return true;
// 分别沿着左右子节点走下去,然后顺便把当前节点的值减掉,
// 左右子节点只要有一个返回true,说明存在这样的结果。
return hasPathSum(root->left, targetSum - root->val)
|| hasPathSum(root->right, targetSum - root->val);
}
def hasPathSum(self, root: Optional[TreeNode], targetSum: int) -> bool:
if not root:
return False
# 如果到叶子节点了,并且剩余值等于叶子节点的值,返回true。
if not root.left and not root.right:
return targetSum == root.val
# 分别沿着左右子节点走下去,然后顺便把当前节点的值减掉,
# 左右子节点只要有一个返回true,说明存在这样的结果。
return (self.hasPathSum(root.left, targetSum - root.val) or
self.hasPathSum(root.right, targetSum - root.val))