LC68----222. 完全二叉树的节点个数(java版)---树

1. 题目描述

完全二叉树的节点个数

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

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

2.代码思路

如果树的根节点为空,则返回0.然后再递归地计算左子树和右子树的节点数,然后将这两个计数相加,并加上当前节点(即根节点),返回总的节点数。

3.代码实现

java 复制代码
/**
 * 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) {
        if(root==null)
        {
            return 0;//如果树的根节点为空,则返回0.
        }
       
       int leftnode=countNodes(root.left);
       int rightnode=countNodes(root.right);

       return leftnode+rightnode+1;

        
    }
}
相关推荐
lijgvnns9 小时前
个人AI编程工具的vibe coding实践:从爬虫到导出Excel的全流程
开发语言·javascript·ecmascript
心之伊始9 小时前
Spring Boot Actuator + Micrometer 实战:自定义业务指标并接入 Prometheus 观测接口耗时
java·spring boot·prometheus·actuator·micrometer
Full Stack Developme9 小时前
Spring Integration 教程
java·后端·spring
青春喂了后端10 小时前
Go Sidecar Status 性能优化
开发语言·性能优化·golang
摇滚侠10 小时前
MyBatis 入门到项目实战 MyBatis 分页插件 65-66
java·开发语言·sql·mybatis
星辰_mya10 小时前
autowired和resource区别
java·后端·spring·架构·原理
我登哥MVP10 小时前
走进 Gang of Four 设计模式:装饰器模式
java·spring boot·设计模式·装饰器模式
CHHH_HHH10 小时前
【C++】哈希表原理与实战:从冲突解决到性能优化
开发语言·数据结构·c++·学习·算法·哈希算法·散列表
Cloud_Shy61810 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第七章 Item 48 - 50)
开发语言·人工智能·笔记·python·microsoft·学习方法
云恒要逆袭10 小时前
Java类型转换详解:小数字转大自动跑,大数字转小要小心
java·后端