题解 | #二叉树根节点到叶子节点的所有路径和#
二叉树根节点到叶子节点的所有路径和
http://www.nowcoder.com/practice/185a87cd29eb42049132aed873273e83
本质就是二叉树的便利 遍历到叶子节点的时候把得到的数加入到队列 最后把所有叶子节点得到的数得一个综合即可
/**
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
class Solution {
public:
/**
*
* @param root TreeNode类
* @return int整型
*/
vector<int>nums;
void traV(TreeNode* root,int num){
if(root == nullptr){
return;
}
num = num*10 + root->val;
if(root->left == nullptr && root->right == nullptr) nums.emplace_back(num);
traV(root->left,num);
traV(root->right,num);
}
int sumNumbers(TreeNode* root) {
// write code here
int ans=0;
traV(root,0);
for(int i = 0;i<nums.size();i++){
ans+=nums[i];
}
return ans;
}
};