Every day a leetcode
题目来源:112. 路径总和
解法1:递归
hasPathSum 函数:询问是否存在从当前节点 root 到叶子节点的路径,满足其路径和为 sum。
假定从根节点到当前节点的值之和为 val,我们可以将这个大问题转化为一个小问题:是否存在从当前节点的子节点到叶子的路径,满足其路径和为 targetSum - val。
于是,这个问题可以用递归实现。
退出条件:走到了空结点
当遇到叶子节点时,判断该值是否等于剩余的targetSum。是,返回 true,不是返回 false。
递归判断节点的左子树和右子树,剩余的targetSum=targetSum-root->val。
代码:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
bool hasPathSum(struct TreeNode* root, int targetSum){
if(root == NULL) return false;
if(root->left == NULL && root->right == NULL) return root->val == targetSum;
return hasPathSum(root->left,targetSum-root->val) || hasPathSum(root->right,targetSum-root->val);
}
结果:
解法2:BFS
使用广度优先搜索的方式,记录从根节点到当前节点的路径和.
使用两个队列,分别存储将要遍历的节点,以及根节点到这些节点的路径和。
代码:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
bool hasPathSum(TreeNode* root, int targetSum) {
if(root == NULL) return false;
queue<TreeNode*> node;
queue<int> value;
node.push(root);
value.push(root->val);
while(!node.empty())
{
TreeNode* curNode=node.front();
int curValue=value.front();
node.pop();
value.pop();
if(curNode->left == NULL && curNode->right == NULL)
{
if(curValue == targetSum) return true;
}
if(curNode->left)
{
node.push(curNode->left);
value.push(curValue+curNode->left->val);
}
if(curNode->right)
{
node.push(curNode->right);
value.push(curValue+curNode->right->val);
}
}
return false;
}
};
结果: