完全二叉树和满二叉树
完全二叉树:(子节点必须是从左至右都存在,不能是中间缺少)
关于根据总节点数求子节点数:(节点的度表示节点拥有的子节点数)
n(总节点数) = N0(表示度为0的节点) + N1(表示度为1的节点) + N2(表示度为2的节点) 根据度来得到所有的节点数
n(总节点数) = 1 + N1(表示度为1的节点) + 2*N2(表示度为2的节点) (根节点,和度为1和2的子节点数来得到总节点数)
根据上面两式消除N2得到 n+1 = 2N0 + N1
因为完全二叉树,所以得
(根节点)当n为偶数时,N1为1 得N0 = n/2
当n为奇数时,N1为0 得N0 = n+1/2
所以得结论,当总节点数为偶数时,叶子节点数为总节点数的一半,当总节点数为奇数时,叶子节点数为总节点数加一后的一半
满二叉树:(每个树的深度的节点数都必须是满的,注意它的总节点数总为奇数)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?