题目要求
给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字。
例如,从根到叶子节点路径 1->2->3 代表数字 123。
计算从根到叶子节点生成的所有数字之和。
说明: 叶子节点是指没有子节点的节点。
解题思路
主要的思想是,我们对每一层的节点进行拼接和累加,什么意思呢?看example1,我们需要拼接1,2和1,3两个数字为12,13。之后因为他们是叶子节点,所以我们要把他们加起来。 如何拼接呢? 最简单的方法,我们使用字符串的形式。这样直接进行数字的拼接就可以了,不用再去个位,十位的进行转换。非常好理解。
要点:
(1)字符串拼接数字
(2)到叶子节点进行累加和。
主要代码python
# Definition for a binary tree node.