zoukankan      html  css  js  c++  java
  • 129. 求根到叶子节点数字之和

    给定一个二叉树,它的每个结点都存放一个 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.

    思路:这是一道很基础很典型的树的深度优先搜索题目,诀窍就是每一次递归,函数要传递 sum和 num。sum用来统计和的,num是路径上的数 目前beat 100%

    class Solution {
        public int sumNumbers(TreeNode root) {
            if(root==null) return 0;
            return sum(root,0,0);
        }
        
        public int  sum(TreeNode root ,int sum,int num){
            if(root.left==null && root.right==null) {
                return sum=sum+num*10+root.val;
            }
            else {
                int left=0,right=0;
                if(root.left!=null) left = sum(root.left,sum,num*10+root.val);
                if(root.right!=null) right = sum(root.right,sum,num*10+root.val);
                return left+right;
            }
        }
    }


  • 相关阅读:
    Go语言v1.8正式发布,有显著的性能提升和变化(go适合服务器编程、网络编程)
    NET生成二维码
    组合模式
    Spring MVC
    前端事件
    Play Framework + ReactiveMongo
    DDD领域驱动设计初探
    jsRender模板引擎
    C#分布式缓存Couchbase
    ABP
  • 原文地址:https://www.cnblogs.com/chen-jack/p/9942273.html
Copyright © 2011-2022 走看看