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;

        
    }
}
相关推荐
江流月照10 小时前
PCIE地址空间介绍
java·服务器·网络
好望角雾眠10 小时前
第四阶段C#通讯开发-1:通讯基础理论,串口,通讯模式,单位转换,代码示例
开发语言·笔记·c#·串口·通讯
不一样的故事12610 小时前
学习Python是一个循序渐进的过程,结合系统学习、持续实践和项目驱动,
开发语言·python·学习
eqwaak010 小时前
科技信息差(9.13)
大数据·开发语言·人工智能·华为·语言模型
郝学胜-神的一滴10 小时前
深入探索 Python 元组:从基础到高级应用
运维·服务器·开发语言·python·程序人生
一只乔哇噻10 小时前
java后端工程师进修ing(研一版‖day44)
java·开发语言·学习·算法
老华带你飞10 小时前
畅阅读小程序|畅阅读系统|基于java的畅阅读系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·畅阅读系统小程序
Ares-Wang10 小时前
Vue3》》eslint Prettier husky
开发语言·javascript·ecmascript
EveryPossible11 小时前
静态箭头连线
开发语言·javascript·ecmascript
NiKo_W11 小时前
Git 版本回退与撤销修改
开发语言·git·安全