当前位置: 首页 > article >正文

力扣222. 完全二叉树的节点个数(Java实现)

222. 完全二叉树的节点个数

1. 思路

这个题最简单的做法就是暴力遍历,时间复杂度为O(n)。

我们现在用低于O(n)的做法解决问题。

对于一棵满二叉树,它的节点数 = 2 h - 1 (h 是指树一共有多少层)

  1. 头节点不断遍历左孩子直至为null,得到树高h。
  2. 遍历头节点右孩子的左边界,直到遍历到最左节点,如果最左节点所在的层数 = h,说明头节点root的左子树是满二叉树。那么左子树的节点数 = 2l - 1,l 是指左子树有多少层。那么root左子树节点数 + root节点数 = 2l - 1 + 1 = 2l 。接着递归遍历root的右子树,求右子树有多少节点,相加即可。
  3. 如果头节点右孩子的最左节点所在的层数 < h (绝不可能大于h,因为是完全二叉树),说明头节点root的右子树是满二叉树。那么root的右子树的节点数 = 2l - 1,l 是指右子树有多少层。那么root右子树节点数 + root节点数 = 2l - 1 + 1 = 2l 。接着递归遍历root的左子树,求左子树有多少节点,相加即可。

image-20250319212820667

有一个递归函数 int f(TreeNode node),返回结果是以node为头节点的完全二叉树有多少个节点。

上图中树有四层高(h = 4),头节点a为第一层。


f(a):

a的右子树的最左节点层数= 3 < 4,说明右子树是满二叉树。而右子树的树高2层。

计算公式:树的总高度h - a的层数 - 1 = 4 - 1 - 1 = 2 ,即右子树的节点数 = 2 2 - 1 = 3。右子树节点数 + a节点数 = 3 + 1 = 4 = 22 。之后递归调用a的左子树b。

f(a) = f(b) + 4


f(b):

b的右子树的最左节点层数 = 4,说明 b 的左子树是满二叉树。b 的 左子树树高2层。

计算公式:树的总高度h - b的层数 = 4 - 2 = 2,即b的左子树节点数 = 22 - 1 = 3。左子树节点数 + b节点数 = 3 + 1 = 4 = 22 。之后递归调用b的右子树c。

f(b) = f© + 4


f©:

c 的右子树为空,也就是右子树的最左节点 != 4,说明c的右子树是满二叉树。只不过是 0 个节点。

计算公式:**树的总高度h - c的层数 - 1 ** = 4 - 3 -1 = 0,即c的右子树节点数 = 20 - 1 = 0。在此基础上加上c节点数 = 0 + 1 = 1。之后递归调用c的左子树d。

f© = f(d) + 1


f(d):

d节点是叶节点,f(d) 直接返回1。


f(a) = f(b) + 4 = 10

f(b) = f© + 4 = 6

f© = f(d) + 1 = 2

f(d) = 1

2. 代码

	public static int countNodes(TreeNode root) {if(root == null){return 0;}return f(root,1,mostLeft(root,1));}/**** @param cur - 当前节点* @param level - 当前节点所在层数* @param h - 整棵树的高度* @return 以cur为头节点的树的高度*/private static int f(TreeNode cur, int level, int h) {if (level == h){return 1;}/***  level 是 cur所在的层数*  level + 1 才是 cur.right所在层数*/if (mostLeft(cur.right,level + 1) == h){/***  cur.right所在层数 = h*  cur的左子树是满二叉树*  1 << (h - level) 意为 2向左移动1 << (h - level)为,即 2^(h - level)*/return (1 << (h - level)) + f(cur.right,level+1,h);}else {/**** cur的右子树是满二叉树*/return (1 << (h - level - 1)) + f(cur.left,level+1,h);}}/*** 求当前节点的最左节点所在的层数* @param cur - 当前节点* @param level - 当前节点的层数* @return 当前节点的最左节点所在的层数*/private static int mostLeft(TreeNode cur, int level) {while (cur != null){level++;cur = cur.left;}/*** 如果整棵树的根节点层数从0开始计数,那么返回level* 可根节点是从1开始计数,返回level-1,自己动笔算一下就明白了*/return level - 1;    }

相关文章:

力扣222. 完全二叉树的节点个数(Java实现)

222. 完全二叉树的节点个数 1. 思路 这个题最简单的做法就是暴力遍历&#xff0c;时间复杂度为O(n)。 我们现在用低于O(n)的做法解决问题。 对于一棵满二叉树&#xff0c;它的节点数 2 h - 1 (h 是指树一共有多少层) 头节点不断遍历左孩子直至为null&#xff0c;得到树高…...

MySQL函数大全(持续更新)

MySQL常用函数 一、字符串函数 函数功能 CONCAT(s1, s2, ...) 拼接字符串 CONCAT_WS(sep, s1, s2, ...) 指定分隔符拼接字符串 SUBSTRING(str, start, length) 截取字符串 LEFT(str, length) 从左边截取指定长度字符串 RIGHT(str, length) 从右边截取指定长度字符串 LENGTH(s…...

Django系列教程(13)——Cookie和Session应用场景及案例

目录 什么是cookie&#xff0c;cookie的应用场景及缺点 Django中如何使用cookie Cookie使用示例 什么是session及session的工作原理 Django中如何使用会话session Session使用示例 小结 HTTP协议本身是”无状态”的&#xff0c;在一次请求和下一次请求之间没有任何状态保…...

element-ui pagination 组件源码分享

pagination 分页组件源码分享&#xff0c;主要从以下三个方面&#xff1a; 1、pagination 组件页面结构。 2、pagination 组件属性。 3、pagination 组件方法。 一、组件页面结构。 二、组件属性。 2.1 small 是否使用小型分页样式&#xff0c;类型为 boolean&#xff0c;…...

【css酷炫效果】纯CSS实现火焰文字特效

【css酷炫效果】纯CSS实现火焰文字特效 缘创作背景html结构css样式完整代码基础版进阶版(冰霜版) 效果图 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u011561335/90492005 缘 创作随缘&#xff0c;不定时更新。 创作背景 刚…...

【java面型对象进阶】------继承实例

继承结构下的标准Javabean 代码如下&#xff1a; package demo10;//定义员工父类 public class Employee {private String id;private String name;private double salary;//构造方法public Employee(){}public Employee(String id,String name,double salary){this.idid;thi…...

Oracle 19c 子分区表索引测试

一、建表语句放在最后&#xff0c;方便查看 二、创建各类索引 --创建本地的主键约束&#xff0c;但必须加上分区键、子分区键MT_O_CODE,M_YMD alter table MS_DMG.A_RED drop constraint MGR_PK_AREAD ; alter table MS_DMG.A_RED add constraint MGR_PK_AREAD primary key …...

【数据分享】1999—2023年地级市固定资产投资和对外经济贸易数据(Shp/Excel格式)

在之前的文章中&#xff0c;我们分享过基于2000-2024年《中国城市统计年鉴》整理的1999-2023年地级市的人口相关数据、染物排放和环境治理相关数据、房地产投资情况和商品房销售面积相关指标数据、社会消费品零售总额和年末金融机构存贷款余额、各类用地面积、地方一般公共预算…...

Spring Boot 与 Couchbase 整合教程

精心整理了最新的面试资料和简历模板&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Spring Boot 与 Couchbase 整合教程 环境要求 JDK 8Spring Boot 2.7.xCouchbase Server 7.xMaven/Gradle 步骤 1&#xff1a;创建Spring Boot项目 使用 st…...

数据结构——串、数组和广义表

串、数组和广义表 1. 串 1.1 串的定义 串(string)是由零个或多个字符组成的有限序列。一般记为 S a 1 a 2 . . . a n ( n ≥ 0 ) Sa_1a_2...a_n(n\geq0) Sa1​a2​...an​(n≥0) 其中&#xff0c;S是串名&#xff0c;单引号括起来的字符序列是串的值&#xff0c; a i a_i a…...

Spring中DI与IOC的关系解析

在Spring框架中&#xff0c;DI&#xff08;依赖注入&#xff09;和IOC&#xff08;控制反转&#xff09;是两个核心概念&#xff0c;它们密切相关但有不同的侧重点。 IOC&#xff08;控制反转&#xff09; IoC 是一种设计原则&#xff0c;将对象的创建和依赖管理交给框架或容…...

pycharm-python國際象棋遊戲代碼

嗯&#xff0c;用户的问题是“pycharm寫關於python國際象棋遊戲代碼”&#xff0c;也就是要用PyCharm来写一个Python的国际象棋游戏代码。我需要先整理一下用户提供的搜索结果&#xff0c;看看有什么相关的信息可以利用。 首先看搜索结果中的各个网页内容。网页1主要讲的是象棋…...

【Java代码审计 | 第十四篇】MVC模型、项目结构、依赖管理及配置文件概念详解

未经许可&#xff0c;不得转载。 文章目录 MVC模型模型&#xff08;Model&#xff09;视图&#xff08;View&#xff09;控制器&#xff08;controller&#xff09;MVC工作流程 项目结构java目录resources目录webapp目录 依赖管理配置文件 MVC模型 MVC&#xff08;Model-View-…...

单片机ADC+NTC温度采集电路学习

文章目录 前言一、NTC是什么&#xff1f;二、NTC重要参数三、实际应用举例四、NTC和PTC的区别总结 前言 NTC常用来检测外部环境或者电池温度&#xff0c;及汽车水温传感器。 有时候电池并不内置NTC&#xff0c;所以需要外置NTC来采集电池温度&#xff0c;注意要紧贴电池&#…...

【Spring Boot 中 `@Value` 注解的使用】

文章目录 一、前言二、Value 注解简介三、Value 注解的常见用法1. 读取 application.properties 或 application.yml 配置值&#xff08;1&#xff09;配置文件示例&#xff08;2&#xff09;Java 代码示例&#xff08;3&#xff09;测试输出 2. 使用 Value 设置默认值3. 读取系…...

分布式数据库系统(DDBS)

分布式数据库系统&#xff08;DDBS&#xff09; (Distributed Database System)的概念及其特点&#xff1a; 分布式数据库系统是一种数据库系统&#xff0c;它将数据分散存储在多个地理上分散的节点上&#xff0c;通过一个全局数据库管理系统&#xff08;DBMS&#xff09;来协调…...

2025年,电脑还需要分区吗?

随着2025年的到来&#xff0c;电脑存储空间已经不像以前那么金贵&#xff0c;固态硬盘&#xff08;SSD&#xff09;容量更大、速度更快&#xff0c;云存储也成了日常标配。许多人开始质疑&#xff1a;电脑还需要像以前那样分区吗&#xff1f; 一、分区到底是什么意思&#xff…...

一个成功的Git分支模型

本作品原发布账号为【白鸽子中文网】&#xff0c;现转至当前账号【飞翔中文网】。 反思备录(2020/3/5) 这个模型构思于2010年&#xff0c;现已过去10余年&#xff0c;(2010年)那时正处于Git诞生后不久。在这10年间&#xff0c;git-flow(本文中提到的分支模型) 在许多软件队伍里…...

Kafka可视化工具KafkaTool工具的使用

Kafka Tool工具 介绍 使用Kafka的小伙伴&#xff0c;有没有为无法直观地查看 Kafka 的 Topic 里的内容而发过愁呢&#xff1f;下面推荐给大家一款带有可视化页面的Kafka工具&#xff1a;Kafka Tool &#xff08;目前最新版本是 3.0.2&#xff09; 注意&#xff1a;以前叫Kafk…...

【嵌入式Linux】基于ArmLinux的智能垃圾分类系统项目

目录 1. 功能需求2. Python基础2.1 特点2.2 Python基础知识2.3 dict嵌套简单说明 3. C语言调用Python3.1 搭建编译环境3.2 直接调用python语句3.3 调用无参python函数3.4 调用有参python函数 4. 阿里云垃圾识别方案4.1 接入阿里云4.2 C语言调用阿里云Python接口 5. 香橙派使用摄…...

同等学力申硕-计算机专业-数学基础-历年真题和答案解析

同等学力申请硕士学位考试是比较适合在职人员的提升学位方式&#xff0c;了解过的人应该都知道&#xff0c;现在社会的竞争压力越来越大&#xff0c;为了提高职业生存能力&#xff0c;提升学位在所难免。 为了通过同等学力申请硕士学位考试&#xff0c;对于计算机专业的人来说…...

网络安全漏洞与修复 网络安全软件漏洞

文章目录 一、软件漏洞的概念 1、信息安全漏洞简述2、软件漏洞3、软件漏洞概念4、软件漏洞的成因分析 二、软件漏洞标准化管理 1、软件漏洞分类2、软件漏洞分级3、安全漏洞管理规范 一、软件漏洞的概念 1、信息安全漏洞简述 信息安全漏洞是信息安风险的主要根源之一&…...

STM32:Default_Handler问题

记录代码进入Default_Handler错误的解决办法 一、 问题表述 在一次调试代码的时候&#xff0c;发现代码卡死在启动文件 startup_at32f423xx_.s 的367行&#xff0c;即 B. 处B.是汇编代码&#xff0c;B&#xff1a;跳转到一个标号&#xff0c;这里跳转到一个‘.’&#xff0c;…...

iwebsec-SQL数字型注入

1.判断是否存在漏洞 添加and 11发现正常显示&#xff0c;添加and 12无回显条目&#xff0c;则存在sql注入漏洞 2.因为有回显&#xff0c;尝试union联合注入&#xff0c;使用order by判断出有3个字段 3.使用union联合注入查看回显位&#xff0c;发现3三个字段均有回显&#xff…...

基于Spring Boot的冷链物流系统的设计与实现的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…...

LLM(6):理解词嵌入

深度神经网络模型&#xff0c;包括 LLM&#xff0c;无法直接处理原始文本。由于文本是分类的&#xff0c;它与用于实现和训练神经网络的数学操作不兼容。因此&#xff0c;我们需要一种方法来将词语表示为连续值向量。 注意&#xff1a;如果读者对向量和张量不太了解&#xff0c…...

SQLMesh系列教程:利用date_spine宏构建日期序列实践指南

引言&#xff1a;为什么需要日期维度表&#xff1f; 在数据分析和报表开发中&#xff0c;日期维度表是不可或缺的基础结构&#xff0c;其中包括一定日期范围的日期序列&#xff0c;每个序列包括对应日期属性&#xff0c;如年季月日、是否周末等。无论是计算日粒度销售额、分析…...

sqlite mmap

https://www.sqlite.org/mmap.html 1. 内存映射 I/O 的基本原理 默认机制&#xff08;传统 I/O&#xff09; SQLite 默认通过 xRead() 和 xWrite() 方法&#xff08;对应 read()/write() 系统调用&#xff09;访问数据库文件。这些方法需要将数据从内核缓冲区复制到用户空间&am…...

Java 大视界 -- 企业数字化转型中的 Java 大数据战略与实践(93)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...

Unity Enlighten与Progressive GPU Lightmapper对比分析

一、技术背景与核心差异 1. 算法原理 Enlighten 基于辐射度算法&#xff08;Radiosity&#xff09;&#xff0c;通过将场景分解为Systems&#xff08;光照关联单元&#xff09;和Clusters&#xff08;计算单元&#xff09;&#xff0c;预计算光照环境中的间接光传输。其核心是…...