【LeetCode222】完全二叉树的节点个数

题目描述

给你一棵 完全二叉树 的根节点 root ,求出该树的节点个数。

完全二叉树 的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层(从第 0 层开始),则该层包含 1~ 2h 个节点。

思路与算法

  1. base cases:
    • 空树:节点的数量是 0
    • 完美二叉树:2^d−1
  2. 递归步骤
    • 递归计算左子树中的节点数
    • 递归计算右子树中的节点数
    • 为当前根节点加 1
  3. 结果组合

代码

python3 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def countNodes(self, root: Optional[TreeNode]) -> int:
        if not root:
            return 0

        left_depth = self.getLeftDepth(root)
        right_depth = self.getRightDepth(root)
        if left_depth == right_depth:
            return (1 << left_depth) - 1 # same as 2^left_depth - 1

        return 1 + self.countNodes(root.left) + self.countNodes(root.right)

    def getLeftDepth(self, node: TreeNode) -> int:
        depth = 0
        while node:
            depth += 1
            node = node.left
        return depth
    
    def getRightDepth(self, node: TreeNode) -> int:
        depth = 0
        while node:
            depth += 1
            node = node.right
        return depth
        

总结

相关推荐
清羽_ls20 分钟前
leetcode-位运算
前端·算法·leetcode·位运算
猫猫头有亿点炸33 分钟前
C语言中小写字母转大写字母
c语言·开发语言·算法
天天扭码1 小时前
一杯珍珠奶茶的时间吃透一道高频面试算法题——搜索二位矩阵Ⅱ
前端·算法·面试
pljnb1 小时前
聚类算法(K-means、DBSCAN)
算法·kmeans·聚类
2301_807611491 小时前
46. 全排列
c++·算法·leetcode·深度优先·回溯
天天扭码2 小时前
一杯蜜桃四季春的时间吃透一道高频面试算法题——旋转图像
前端·算法·面试
爱的叹息2 小时前
【java实现+4种变体完整例子】排序算法中【堆排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格
java·算法·排序算法
天天扭码2 小时前
一桶泡面的时间解决高频面试算法题——螺旋矩阵
前端·算法·面试
长安思2 小时前
在C#串口通信中,一发一收的场景,如何处理不同功能码的帧数据比较合理,代码结构好
java·jvm·算法
CoovallyAIHub2 小时前
MobileNetV2:面向移动端的高效神经网络架构革新——突破轻量化模型的设计边界
人工智能·算法·计算机视觉