sum-root-to-leaf-numbers
题目描述
题目描述
给定一个仅包含数字0-9的二叉树,每一条从根节点到叶子节点的路径都可以用一个数字表示。
例如根节点到叶子节点的一条路径是1->2->3,那么这条路径就用123来代替。
找出根节点到叶子节点的所有路径表示的数字之和
例如:
1↵ / ↵ 2 3
根节点到叶子节点的路径1->2用数字12代替
根节点到叶子节点的路径1->3用数字13代替
所以答案为12+13=25
题目解析
题目要求求出二叉树的所有路径之和,所以应该使用递归调用,向下依次累加根节点的值,找到一条路径(最后的叶子节点)后向上返找其他的路径,最后返回累加的结果。
原题地址
代码
public class Solution {
public int sumNumbers(TreeNode root) {
if(root==null)
return 0;
return getRes(root,0);
}
public int getRes(TreeNode root, int sum){
if(root == null){
return 0;
}
sum = sum * 10 + root.val;
if(root.left == null && root.right == null){
return sum;
}
int left = getRes( root.left,sum);
int rigth = getRes(root.right,sum);
return left+rigth;
}
}