给你一个二叉树的根节点 root
,树中每个节点都存放有一个 0
到 9
之间的数字。
每条从根节点到叶节点的路径都代表一个数字:
- 例如,从根节点到叶节点的路径
1 -> 2 -> 3
表示数字123
。
计算从根节点到叶节点生成的 所有数字之和 。
叶节点 是指没有子节点的节点。
示例 1:
输入:root = [1,2,3] 输出:25 解释: 从根到叶子节点路径1->2
代表数字12
从根到叶子节点路径1->3
代表数字13
因此,数字总和 = 12 + 13 =25
示例 2:
输入:root = [4,9,0,5,1] 输出:1026 解释: 从根到叶子节点路径4->9->5
代表数字 495 从根到叶子节点路径4->9->1
代表数字 491 从根到叶子节点路径4->0
代表数字 40 因此,数字总和 = 495 + 491 + 40 =1026
一发AC直冲天灵盖 !
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
int sumNumbers(TreeNode* root) {
unordered_map<TreeNode*, int> map; //建立哈希数组,以树杈为索引
int sum=0;
queue<TreeNode*> weizhi; //创立队列,可以不需要递归
weizhi.push(root);
map[root]=root->val; //这步不要忘了,把根节点的数值记载一下
while(!weizhi.empty()){
TreeNode* root1=weizhi.front(); //开始传递索引
weizhi.pop();
//由题意,进行相加
if(root1->right!=nullptr){
map[root1->right]=map[root1]*10+(root1->right->val);
weizhi.push(root1->right);
}
if(root1->left!=nullptr){
map[root1->left]=map[root1]*10+(root1->left->val);
weizhi.push(root1->left);
}
//遍历到树杈了就记载这个叶子节点的总数
if(root1->right==nullptr&&root1->left==nullptr) sum+=map[root1];
//cout << "sum"<< sum<< endl;
}
//最后返回结果
return sum;
}
};
官方深度优先搜索
class Solution {
public:
int dfs(TreeNode* root, int prevSum) {
if (root == nullptr) {
return 0;
}
int sum = prevSum * 10 + root->val;
if (root->left == nullptr && root->right == nullptr) {
return sum;
} else {
return dfs(root->left, sum) + dfs(root->right, sum); //注意这里的递归
}
}
int sumNumbers(TreeNode* root) {
return dfs(root, 0);
}
};
官方广度优先搜索
class Solution {
public:
int sumNumbers(TreeNode* root) {
if (root == nullptr) {
return 0;
}
int sum = 0;
queue<TreeNode*> nodeQueue;
queue<int> numQueue; //这里用队列记载节点对应的数值,而不是哈希数组
nodeQueue.push(root);
numQueue.push(root->val);
while (!nodeQueue.empty()) {
TreeNode* node = nodeQueue.front();
int num = numQueue.front();
nodeQueue.pop();
numQueue.pop();
TreeNode* left = node->left;
TreeNode* right = node->right;
if (left == nullptr && right == nullptr) {
sum += num;
} else {
if (left != nullptr) {
nodeQueue.push(left);
numQueue.push(num * 10 + left->val);
}
if (right != nullptr) {
nodeQueue.push(right);
numQueue.push(num * 10 + right->val);
}
}
}
return sum;
}
};