LeetCode 1022. Sum of Root To Leaf Binary Numbers

🔗 https://leetcode.com/problems/sum-of-root-to-leaf-binary-numbers

题目

  • 给一个只有 0 和 1 的二叉树
  • 从 root 到 leaf 的 path 组成一个二进制数
  • 返回这棵树的所有路径和

思路

  • dfs 遍历,记录 path 的二进制数
  • 匿名函数减少参数的传递,代码很好写!

代码

cpp 复制代码
/**
 * 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 sumRootToLeaf(TreeNode* root) {
        int sum = 0;

        auto dfs = [&](this auto&& self, TreeNode* node, int presum) -> void{
            if (node->right == nullptr && node->left == nullptr) {
                sum = sum + presum * 2 + node->val;
                return;
            }
            if (node->right) self(node->right, presum * 2 + node->val);
            if (node->left) self(node->left, presum * 2 + node->val);
        };
        dfs(root, 0);
        return sum;
        
    }
};
相关推荐
vivo互联网技术16 分钟前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望2 小时前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰2 小时前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法
地平线开发者12 小时前
J6B vio scenario sample
算法
BothSavage1 天前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn1 天前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说2 天前
判断回文字符串,从一行代码到双指针优化
算法