222. 完全二叉树的节点个数
题目描述
- 给你一棵 完全二叉树 的根节点
root
,求出该树的节点个数。 - 完全二叉树 的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第
h
层,则该层包含1~ 2h
个节点。
算法分析
- 将问题分解为只有一个节点的情况,定义一个计算的变量
- 当前节点不为空时
- 就将结果加一,然后分别向左向右递归
- 如果当前节点为空,就不作处理
- 最后返回计算后的结果
代码实现
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode() {}
* TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) {
* this.val = val;
* this.left = left;
* this.right = right;
* }
* }
*/
class Solution{
public int countNodes(TreeNode root) {
int reslut = 0;
//判断当前节点
if (root != null){
reslut +=1;
//向左递归
reslut += countNodes(root.left);
//向右递归
reslut += countNodes(root.right);
}
return reslut;
}
}
涉及知识点
- 树
- 完全二叉树
- 递归