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;
            }
        }
    }


  • 相关阅读:
    python3.6.4源码安装
    centos 6 中恢复删除的文件
    mysql5.6.8源码安装
    zookeeper集群搭建
    vmware 12中安装苹果系统
    docker被入侵后.............
    关于docker
    关于redis
    人生的价值 幸福感
    c# 泛型
  • 原文地址:https://www.cnblogs.com/chen-jack/p/9942273.html
Copyright © 2011-2022 走看看