【LeetCode-中等题】 222. 完全二叉树的节点个数

2023-09-21 20:51:50

题目

在这里插入图片描述

方法一:把该题当做一个普通的二叉树来做(任何遍历都可以)

例如:二叉树的前序遍历(维护一个全局变量)递归无返回值

class Solution {
    int num = 0;
    public int countNodes(TreeNode root) {
        dfs(root);
        return num;
    }
    public void dfs(TreeNode root){
        if(root == null) return;
        num++;
        dfs(root.left);
        dfs(root.right);
    }
}

方法二:利用完全二叉树的性质来做

  1. 当前节点只要满足完全二叉树的话,可以通过2^depth-1来计算以当前节点为父节点的数的节点数,这样减少很多递归操作,不需要递归找到每一个节点
  2. 当前节点不满足二叉树的性质 ,那就走常规递归到下一层,再来判断

一定要画图 模拟递归过程
在这里插入图片描述
在这里插入图片描述

lass Solution {
    public int countNodes(TreeNode root) {
        return dfs(root);
    }
    public int dfs(TreeNode root){
        if(root == null) return 0;
        int leftsum = 1;//root不为null  自然高度起始就是1
        int rightsum = 1;
        TreeNode left = root.left;
        TreeNode right = root.right;
        //寻找以该节点为父节点的左右子树的高度
        while(left!=null){
            left = left.left;
            leftsum++;
        }
         while(right!=null){
            right = right.right;
            rightsum++;
        }
        //如果左右子树的高度相等  说明以该节点为父节点的数是完全二叉树  ,所以可以按照完全二叉树的性质来计算节点数 2的高度次方-1  
        if(rightsum == leftsum) return (int)Math.pow(2, rightsum) - 1;
        //如果左右子树的高度不相等  那么进入下一层常规递归
        int left_ = dfs(root.left);
        int right_ = dfs(root.right);
        return left_+right_+1;//最后返回左右子树节点数之和在加上本节点
    }
}
更多推荐

WPF行为

行为是一款重用用户界面代码的更有挑战性的工具。其基本思想是:使用行为封装一些通用UI功能。如果具有适当的行为,可使用一两行XAML标记将其附加到任意元素,从而节省编写和调试代码的工作。样式提供了重用一组属性设置的实用方法。它们帮助构建一致的、组织良好的界面迈出了重要的第一步——但它们还有许多限制。问题是在典型的应用程序

多级缓存基础架构组件设计

基础架构组件-缓存背景目的缓存架构服务层多级缓存核心流程设计1、缓存介质2、如何实现spring注解方式多级缓存如何实现缓存的永久存储又可以过期刷新,而避免缓存失效带来的一系列缓存雪崩、击穿等问题实现缓存包装类多级缓存处理器实现1、lookup(Objectkey)2、get(Objectkey)3、重头戏get(Ob

Lua 多返回值

Lua这门神奇的语言可以在函数里面返回多个值具体函数如下functionmulti_return()return2,"hellowworld"endlocala,b=multi_return();--多个都返回print(a,b)localm=multi_return();--默认返回第一个返回值print(m)unp

搭建Flink集群、集群HA高可用以及配置历史服务器

Flink集群搭建Flink集群搭建集群规划下载并解压安装包修改集群配置分发安装目录启动集群访问WebUIFlink集群HA高可用概述集群规划配置flink配置master、workers配置ZK分发安装目录启动HA集群测试Flink参数配置配置历史服务器概述配置启动、停止历史服务器提交一个Job任务查看历史Job信息

数据结构上机练习——单链表的基本操作、头文件、类定义、main函数、多种链表算法的实现,含注释

文章目录单链表的基本操作实现1.头文件2.类定义和多种算法的实现2.1创建空表2.2头插法创建n个元素的线性链表2.3一个带头节点的链表存放一组整数,设计一个算法删除值等于x的所有节点。2.4计算线性表中值为偶数的节点个数2.5一个带头节点的单链表heada存放一组整数,设计分裂heada算法,偶数放在heada中,奇

二叉树的概念、存储及遍历

一、二叉树的概念1、二叉树的定义二叉树(binarytree)是n个结点的有限集合,该集合或为空集(空二叉树),或由一个根结点与两棵互不相交的,称为根结点的左子树、右子树的二叉树构成。二叉树的特点是:(1)每个结点最多有两棵子树,故二叉树中不存在度大于2的结点。(2)二叉树是有序的,其次序不能任意颠倒,即使树中的某个结

利用Socks5代理IP加强跨界电商爬虫的网络安全

随着跨界电商的兴起,爬虫技术在这个领域变得越来越重要。然而,网络安全一直是一个值得关注的问题。在本文中,我们将讨论如何利用代理IP和Socks5代理来增强跨界电商爬虫的网络安全,确保稳定和可靠的数据采集,同时避免封禁和风险。背景跨界电商是一个竞争激烈的领域,市场上的商品信息和价格常常会变动。为了保持竞争力,电商企业需要

CFGPT: Chinese Financial Assistant with Large Language Model

本文是LLM系列文章,针对《CFGPT:ChineseFinancialAssistantwithLargeLanguageModel》的翻译。CFGPT:大型语言模型的中文财务助理摘要1引言2相关工作3数据集4模型和训练5应用6结论摘要大型语言模型(LLM)在金融领域的自然语言处理任务中显示出巨大的潜力。在这项工作中

医疗虚拟仿真和虚拟现实有什么区别?哪个更好?

随着我们在仿真教育中越来越多地使用新技术,区分虚拟模式的类型很重要。虚拟仿真是一个统称,用来概括术语来描述各种基于仿真的体验,从基于屏幕的平台到沉浸式虚拟现实。然而,各虚拟平台在保真度、沉浸感和临场感的水平上有很大差异。医疗教育中存在许多虚拟解决方案的空间,对于护理虚拟仿真课程来说,没有"一刀切"的模式。在此就给大家介

如何完美通过token获取用户信息(springboot)

1.什么是Token?身份验证令牌(AuthenticationToken):在身份验证过程中,“token”可以表示一个包含用户身份信息的令牌。例如Token(JWT)是一种常见的身份验证令牌,它包含用户的身份信息(例如用户名或用户ID)以及其他相关信息,如权限或过期时间。无意义令牌token,这种一般在获取后通过n

芯片SoC设计你了解吗?

数字IC设计根据岗位性质一般包含SOC设计,前端设计,ASIC设计,逻辑设计,IP设计,CPU设计等。有人说:做IP设计就是翻译官,做SOC设计就是连连看。SoC设计是做什么的?与IP设计有什么不同?IP设计工程师每天的工作,编码,debug,接口定好了,时钟只给一个,内部不让分频。不用做过异步处理。按照公司的编码规范

热文推荐