【Leetcode】1022.从根到叶的二进制数之和

1022.从根到叶的二进制之和

题目描述

给出一棵二叉树,其上每个结点的值都是 0 或 1 。每一条从根到叶的路径都代表一个从最高有效位开始的二进制数。例如,如果路径为 0 -> 1 -> 1 -> 0 -> 1,那么它表示二进制数 01101,也就是 13

code
 /**
     * 1022. 从根到叶的二进制数之和
     * @param root
     * @return
     */
    public int sumRootToLeaf(TreeNode root) {
        return sumRootToLeafDfs(root, 0);
    }

    private int sumRootToLeafDfs(TreeNode root, int sum){
        if (root == null){
            return 0;
        }
        sum = sum * 2 + root.val;
        if (root.left == null && root.right == null){
            return sum;
        }
        return sumRootToLeafDfs(root.left, sum) + sumRootToLeafDfs(root.right, sum);
    }
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容