算法学习:112. 路径总和

路径总和

题目链接:力扣题目链接
难度:简单
给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。
叶子节点 是指没有子节点的节点。
示例
转载力扣官网
输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。

定义一个二叉树节点

 //二叉树节点的定义。
 class TreeNode {
     int val;
     TreeNode left;
     TreeNode right;
     TreeNode(){}
     TreeNode(int val){
         this.val = val;
     }
     TreeNode(int val,TreeNode left,TreeNode right){
         this.val = val;
         this.left = left;
         this.right = right;
     }
}

思路

假定从根节点到当前节点的值之和为val,我们可以将这个大问题转化为一个小问题:是否存在从当前节点到叶子的路径,满足其路径和为sum-val。

使用广度优先搜索,记录从根节点到当前节点的路径和,以防止重复计算。使用两个队列,分别存储将要遍历的节点,以及根节点到这些节点的路径和。

递归代码

class Solution{
	public boolean hasPathSum(TreeNode root,int targetSum){
		if(root == null)	return false;
		//当找到叶子节点时,如果剩下的targetSum值刚好和当前节点值相等就返回true
		if(root.left == null && root.right == null) return root.val == targetSum;
		//分别从左子树和右子树去找叶子节点 每次减去走过的节点值
		return hasPathSum(root.left,targetSum - root.val) || hasPathSum(root.right,targetSum - root.val);
	}
}

迭代代码

class Solution{
	public boolean hasPathSum(TreeNode root,int targerSum){
		//判断根节点存在不存在,不存在返回false
		if(root == null)	return false;
		//创建两个队列分别存放节点和节点值 
		Queue<TreeNode> queueNode = new LinkedList<>();
		Queue<Integer> queueVal = new LinkedList<>();
		queueNode.offer(root);
		queueVal.offer(root.val);
		while(!queueNode.isEmpty()){
			TreeNode node = queueNode.poll();
			Integer value = queueVal.poll();
			//如果取出的节点不存在子节点,那么就判断路径和与目标值是否相等
			if(node.left == null && node.right == null){
				if(value == targerSum){
					return true;
                }
			}
			//判断有左子节点的话
			if(node.left != null){
				//将左子节点加入第一个队列
				queueNode.offer(node.left);
				//将当前左子节点的值与路径和相加加入第二个队列
				queueVal.offer(node.left.val + value);
			}
			if(node.right != null){
				queueNode.offer(node.right);
				queueVal.offer(node.right.val + value);
			}
		}	
		return false;
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

As_theWind

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值