首页 > 其他 > 详细

leetcode129

时间:2019-05-09 17:58:42      阅读:125      评论:0      收藏:0      [点我收藏+]

题目:

给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字。

例如,从根到叶子节点路径 1->2->3 代表数字 123

计算从根到叶子节点生成的所有数字之和。

说明: 叶子节点是指没有子节点的节点。

示例 1:

输入: [1,2,3]
    1
   /   2   3
输出: 25
解释:
从根到叶子节点路径 1->2 代表数字 12.
从根到叶子节点路径 1->3 代表数字 13.
因此,数字总和 = 12 + 13 = 25.

示例 2:

输入: [4,9,0,5,1]
    4
   /   9   0
 / 5   1
输出: 1026
解释:
从根到叶子节点路径 4->9->5 代表数字 495.
从根到叶子节点路径 4->9->1 代表数字 491.
从根到叶子节点路径 4->0 代表数字 40.
因此,数字总和 = 495 + 491 + 40 = 1026.
 

解题思路:

递归(调用自身)

结束条件: 1. t == NULL;

      2.t->left = NULL&&t->right = NULL

代码:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    int sumNumbers(TreeNode* root) {
        int res = 0;
        int out = 0;
        helper(root, out, res);
        return res;
    }
    void helper(TreeNode* t, int out, int &res){
        if(t == NULL) return;
        out = out * 10 + t->val;
        if(!t->left && !t->right){
            res += out;
            return;
        }
        helper(t->left,out,res);
        helper(t->right,out,res);
    }
};

 

leetcode129

原文:https://www.cnblogs.com/yxlsblog/p/10839667.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!