力扣刷题 Days18-第二题-完全二叉树的节点个数(js)

1,题目

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

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

2,代码求解

/*** @param {TreeNode} root* @return {number}*/
var countNodes = function(root) {const exists = (root,level,k)=>{// 最高位是 1,其余各位从高到低表示从根节点到第 k 个节点的路径,// 0 表示移动到左子节点,1 表示移动到右子节点let bits = 1 << (level -1);let node = root;while(node!=null && bits>0){if((bits & k)){node = node.right;}else{node = node.left;}// bits左移且改变值 >>= bits >>= 1;}return !(node === null);}if(root === null){return 0;}// 树的层数为 0 1 2 3 ... levellet level =0;let node = root;while(node.left != null){node = node.left;level++;}// 节点的上下限let low = 1 << level;let high = ( 1 << (level + 1)) -1;while(low < high){const mid = Math.floor((high - low +1)/2) + low;if(exists(root,level,mid)){low = mid;}else{high = mid-1;}}return low;};

3,学习与总结

3.1 树的基本知识

对于任意二叉树,都可以通过广度优先搜索或深度优先搜索计算节点个数,时间复杂度和空间复杂度都是 O(n),其中 n是二叉树的节点个数。

(1)完全二叉树节点数的计数

规定根节点位于第 0 层,完全二叉树的最大层数为 h。
节点个数范围

(2)位运算-右移操作 (>>)

在二进制中,右移操作>>意味着将一个数的所有位向右移动指定的位数。
对于无符号整数,左侧空出的位将被填充为0。
对于有符号整数,行为可能依赖于具体的语言和编译器:一般来说,算术右移(针对有符号整数)会将左侧空出的位填充为原来的符号位(即保持正负号不变),而逻辑右移总是填充0(适用于无符号整数)。

示例
假设a的值为8,我们用a >>= 2来举例说明:
8的二进制表示为1000。
将1000向右移动2位,结果是0010。
将0010(十进制中的2)重新赋值给a。
因此,执行a >>= 2后,a的新值将是2。

(3) 过程总结

核心: 如何判断节点是否存在
如果第k个节点位于第h层,则k的二进制表示包含h+1位,其中最高位是1,其余各位从高到低表示从根节点到第k个节点的路径,且0表示左子节点,1表示右子节点。从而,通过位运算得到第k个节点对应的路径,判断该路径对应的节点是否存在;

const exists = (root,level,k)=>{let bits = 1 << (level -1);let node = root;while(node!=null && bits>0){if((bits & k)){node = node.right;}else{node = node.left;}// bits左移且改变值 >>= bits >>= 1;}return !(node === null);}

问题的转化:

首先,通过递归判断左子树是否为空,算出数的最大深度;
其次,求出该完全二叉树节点数范围;
最后,判断最后一层中的某个节点是不是最后一个节点;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/746655.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【CFD小工坊】尝试完成一个简单的溃坝流算例(2)——get_val系列函数

【CFD小工坊】尝试完成一个简单的溃坝流算例&#xff08;2&#xff09;——get_val系列函数 前言设计思路代码讲解get_int_val函数Trim函数其余get系列函数 前言 在上一个博文《尝试完成一个简单的溃坝流算例&#xff08;1&#xff09;》中&#xff0c;我们提到了gat_val系列函…

有没有能用蓝牙的游泳耳机?四大年度最佳游泳耳机由衷推荐

随着科技的不断发展&#xff0c;游泳爱好者们对于游泳耳机的追求也越来越高。在游泳过程中&#xff0c;音乐和播客是许多泳者们的最佳伴侣&#xff0c;它能帮助他们保持节奏、提高兴趣。然而&#xff0c;传统的有线耳机在水下容易产生拉扯&#xff0c;不仅影响游泳体验&#xf…

【Linux操作系统】:Linux进程概念(2)

一、Z(zombie)-僵尸进程 1.僵尸进程概念 故事 张三每天都有跑步的习惯&#xff0c;这一天他和往常一样跑步&#xff0c;跑了两三圈&#xff0c;突然跑在它前面的一个人倒在地上不动了&#xff0c;作为热心市民张三赶紧报警并且拨打120。很快120就来了&#xff0c;但是没过几分…

使用 QLoRA 在 Google Colab 中微调 Mistral 7b(完整指南)

使用 QLoRA 在 Google Colab 中微调 Mistral 7b&#xff08;完整指南&#xff09; 在本文中&#xff0c;我们将在一个名为 Enlighten 的游戏的整个代码库上微调 Mistral 7b&#xff0c;所有这些都在 Google Colab&#xff08;或 Kaggle&#xff09;中免费提供合成数据。在我们的…

深度学习 精选笔记(11)深度学习计算相关:GPU、参数、读写、块

学习参考&#xff1a; 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增)&#xff0c;以达到集多方教程的精华于一文的目的。 ③非常推荐上面&#xff08;学习参考&#x…

中科数安 | 企业办公透明加密系统,终端文件数据 \ 资料防泄密管理软件

#公司办公文件数据 \ 资料防泄密软件系统# "中科数安"是一家专注于数据安全领域的公司&#xff0c;其提供的企业办公加密系统是一种针对企事业单位内部数据安全需求而设计的解决方案。该系统通过先进的加密技术&#xff0c;对企业在日常办公过程中产生的各类敏感信息…

浙大版《数据结构学习与实验指导(第2版)》笛卡尔树

笛卡尔树 题目描述 笛卡尔树是一种特殊的二叉树&#xff0c;其结点包含两个关键字K1和K2。首先笛卡尔树是关于K1的二叉搜索树&#xff0c;即结点左子树的所有K1值都比该结点的K1值小&#xff0c;右子树则大。其次所有结点的K2关键字满足优先队列&#xff08;不妨设为最小堆&am…

实景剧本杀小程序开发搭建

开发搭建实景剧本杀小程序需要以下步骤&#xff1a; 1. 确定小程序的开发语言和框架&#xff1a;根据项目需求和小程序的功能选择合适的开发语言和框架&#xff0c;如微信小程序、React Native等。 2. 设计小程序界面和功能&#xff1a;根据项目需求设计小程序界面和功能&…

MySQL--索引常见面试题详解

索引的设计原则&#xff1f; 在 where 子句中出现的列&#xff0c;建议设计索引。基数较小的列&#xff0c;不建议设计索引。尽量只用短索引&#xff0c;可以节省索引空间。不要过度索引&#xff0c;多设计联合索引&#xff0c;因为索引也有时间和空间的消耗。 创建索引需要注…

【css面试题】弹性盒布局模型 flex 全部知识点整理

一、基本语法 flex-basis 在分配多余空间之前&#xff0c;占据的主轴空间&#xff0c;相当于 widthflex-grow 定义项目的放大比例(存在剩余空间是否放大)默认为0 &#xff08;即如果存在剩余空间也不放大&#xff09;flex-shrink 定义项目的缩小比例&#xff08;空间不足&…

Mysql隔离级别的实现

Mysql隔离级别的实现 mysql隔离级别是通过MVCC锁来实现的&#xff0c;MVCC用来实现读已提交、可重复读 Mysql幻读的解决 1.针对快照读&#xff0c;通过 MVCC 方式解决了幻读 补充:串行化所有的数据库都没做&#xff0c;不过mvcc实现的效果跟串行化差不太多了&#xff0c;可以…

突飞猛进,智能饮品机器人如何助力实体经济?

近日&#xff0c;财务部公布了2024年第一季度及全年财报。数据显示&#xff0c;连锁品牌增长速度惊人&#xff0c;这其中不得不提到智能饮品机器人的使用&#xff0c;为不同的品牌门店拼速度、抢点位立下了不小的功劳&#xff0c;那么智能饮品机器人到底如何助力各门店&#xf…

Outlook API发送邮件的方法?如何设置接口?

如何使用Outlook API发送电子邮件&#xff1f;怎么调用API接口&#xff1f; 为了满足更高级别的需求&#xff0c;我们可能需要通过编程的方式来操作Outlook&#xff0c;这时候&#xff0c;Outlook API就显得尤为重要了。那么&#xff0c;如何使用Outlook API发送邮件呢&#x…

Spring Security自定义认证授权过滤器

自定义认证授权过滤器 自定义认证授权过滤器1、SpringSecurity内置认证流程2、自定义Security认证过滤器2.1 自定义认证过滤器2.2 定义获取用户详情服务bean2.3 定义SecurityConfig类2.4 自定义认证流程测试 3、 基于JWT实现无状态认证3.1 认证成功响应JWT实现3.2 SpringSecuri…

OceanBase中binlog service 功能的试用

OBLogProxy简介 OBLogProxy即OceanBase的增量日志代理服务&#xff0c;它可与OceanBase建立连接并读取增量日志&#xff0c;从而为下游服务提供了变更数据捕获&#xff08;CDC&#xff09;的功能。 关于OBLogProxy的详尽介绍与具体的安装指引&#xff0c;您可以参考这篇官方OB…

基于R语言的水文、水环境模型优化技术及快速率定方法与多模型教程

原文链接&#xff1a;基于R语言的水文、水环境模型优化技术及快速率定方法与多模型教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247597847&idx7&snd71869f1290d0ef9dd7fd3f74dd7ca33&chksmfa823ef0cdf5b7e655af5e773a3d3a1b200632a5981f99fe72f0…

普林斯顿算法讲义(一)

原文&#xff1a;普林斯顿大学算法课程 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 1. 基础知识 原文&#xff1a;algs4.cs.princeton.edu/10fundamentals 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 概述。 本书的目标是研究各种重要和有用的算法——…

多线程编程

多线程写作类 倒计时协调器CountDownLatch 某个线程需要等待其他线程执行到特定操作结束即可。例如&#xff1a;在多Web服务中&#xff0c;在启动指定服务时需要启动若干启动过程中比较耗时的服务&#xff0c;为了尽可能减少服务启动过程的总耗时&#xff0c;该服务会使用专门…

深入探讨MES管理系统与MOM系统之间的关系

在制造业的信息化浪潮中&#xff0c;各种系统与技术层出不穷&#xff0c;其中MES制造执行系统和MOM制造运营管理无疑是备受瞩目的两大主角。尽管它们都是制造业信息化不可或缺的部分&#xff0c;但许多人对它们之间的区别与联系仍感到困惑。本文将对MES管理系统和MOM系统进行深…

uniapp小程序上传oss

uniapp上传小程序代码 import crypto from crypto-js; import { Base64 } from js-base64/base64.js; // 计算oss签名。 function computeSignature(accessKeySecret, canonicalString) {return crypto.enc.Base64.stringify(crypto.HmacSHA1(canonicalString, accessKeySecre…