题目:给出一个完全二叉树,求出该树的节点个数。
说明:
完全二叉树的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2h 个节点。
示例:
思路:这道题第一想法就是暴力递归,从根节点开始依次向下搜索左孩子与右孩子,如果有则数量+1,并且在最后的结果也需要+1(因为根节点也要计算进去)
代码:
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def countNodes(self, root: TreeNode) -> int:
if not root:
return 0
else:
return 1 + self.countNodes(root.left) + self.countNodes(root.right)
题目来自LeetCode第222题