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;

        
    }
}
相关推荐
m0_748229992 分钟前
ThinkPHP快速入门:从零到实战
c语言·开发语言·数据库·学习
liu****3 分钟前
三.Qt图形界面开发完全指南:从入门到掌握常用控件
开发语言·c++·qt
阿蒙Amon12 分钟前
C#每日面试题-Thread.Sleep和Task.Delay的区别
java·数据库·c#
Haooog13 分钟前
AI应用代码生成平台
java·学习·大模型·langchain4j
布茹 ei ai15 分钟前
Python屏幕监视器 - 自动检测屏幕变化并点击
开发语言·python
爬山算法26 分钟前
Hibernate(67)如何在云环境中使用Hibernate?
java·后端·hibernate
小龙报29 分钟前
【C语言进阶数据结构与算法】单链表综合练习:1.删除链表中等于给定值 val 的所有节点 2.反转链表 3.链表中间节点
c语言·开发语言·数据结构·c++·算法·链表·visual studio
黎雁·泠崖36 分钟前
Java抽象类与接口:定义+区别+实战应用
java·开发语言
2301_7925800040 分钟前
xuepso
java·服务器·前端
cfqq19891 小时前
Settings,变量保存
开发语言·c#