数据结构之树的性质总结

节点的度:该节点拥有的孩子个数

叶子节点:度为0的节点

层数:根节点为第一层,根的子节点为第二层,以此类推

所有树的性质:所有节点的总度数等于节点数减一

完全m叉树性质

完全m 叉树,节点的度数最大为m ,且必须按照从上到下从左到右的顺序依次填满,叶子节点只出现在倒数第一层和倒数第二层,如以下为一个完全三叉树

(1)第i 层最多拥有的节点个数为

(2)d 层的完全m 叉树最多拥有的节点个数为

假设完全m 叉树有n 个节点

(3) n 个结点的完全m 叉树的深度为 , ceil 表示向上取整

(4) 当i<d 时,第i 层节点个数为

d 层的节点个数为

(5)在满m 叉树中,一个编号为p 的结点(编号从1开始),它的深度是 ,它的父节点编号为 ,易得该结点的第k-1 个孩子的编号为p*k ,所以推导出该结点的第i 个孩子的编号为  

(6)对于n 个结点的二叉树,按从上到下,从左到右依次给结点编号

i 的双亲结点为i//2 ,若n<2i ,则i 是叶子结点,若n≥2i ,则其左孩子为2i ,若n≥2i+1 ,则其右孩子是结点2i+1 ,若n<2i+1 ,则其无左孩子

(7) n 个结点的不同二叉树有

经典例题

已知一个二叉树有x0 个叶子结点,则该二叉树的总结点数至少是

需要最少的结点,则除了叶子结点外其它结点度数都为2,设度数为2的结点有x2 个,则根据度数性质:所有节点的总度数等于节点数减一

所以该二叉树的总结点数至少是

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

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

相关文章

AI预测福彩3D第32弹【2024年4月10日预测--第7套算法开始计算第5次测试】

今天咱们继续进行进行第7套算法的测试&#xff0c;今天是第5次测试&#xff0c;昨天7码大方案错过&#xff0c;四码小方案直选命中&#xff0c;组选命中。这套算法的目标是争取稳定7码方案中的第一套方案&#xff0c;争取四码小方案的命中率达到50%(十期命中5期&#xff0c;目前…

C# 操作PDF表单 - 创建、填写、删除PDF表单域

通常情况下&#xff0c;PDF文件是不可编辑的&#xff0c;但PDF表单提供了一些可编辑区域&#xff0c;允许用户填写和提交信息。PDF表单通常用于收集信息、反馈或进行在线申请&#xff0c;是许多行业中数据收集和交换的重要工具。 PDF表单可以包含各种类型的输入控件&#xff0…

实验1 eNSP安装与使用

实验1 eNSP安装与使用 一、 原理描述二、 实验目的三、 实验内容四、 实验步骤1.下载并安装eNSP2.eNSP软件界面3.搭建并运行网络拓扑4. Wireshark 捕获分组并分析 一、 原理描述 eNSP&#xff08;Enterprise Network Simulation Platform&#xff09;是由华为提供的免费网络模…

LeetCode:1702. 修改后的最大二进制字符串(贪心 Java)

目录 1702. 修改后的最大二进制字符串 题目描述&#xff1a; 实现代码与解析&#xff1a; 贪心 原理思路&#xff1a; 1702. 修改后的最大二进制字符串 题目描述&#xff1a; 给你一个二进制字符串 binary &#xff0c;它仅有 0 或者 1 组成。你可以使用下面的操作任意次对…

ES6:promise基本使用讲解

一、Promis简介 1.是什么 Promise 是异步编程的一种解决方案。在ES6中&#xff0c;promise对象是一个构造函数&#xff0c;用来生成promise实例。 2.为什么需要promise 在出现promise之前&#xff0c;JS没有一个统一的、标准的异步编程模式&#xff0c;各种库和框架各自采用…

idea中jdk版本的配置

配置JDK版本的步骤如下&#xff1a; 下载JDK安装文件&#xff1a;首先&#xff0c;需要从Oracle官方网站&#xff08;https://www.oracle.com/java/technologies/javase-jdk8-downloads.html&#xff09;下载适合您操作系统的JDK版本。 安装JDK&#xff1a;双击下载的安装文件…

什么是 DNS 记录?

DNS记录是存储在DNS服务器上的文本指令。它们表明与一个域名相关的IP地址&#xff0c;也可以提供其他信息。DNS记录是计算机用语&#xff0c;指域名系统&#xff08;Domain Name System&#xff0c;简称DNS&#xff09;中的一条记录&#xff0c;这条记录存储于DNS服务器中。每一…

【LeetCode热题100】【二叉树】翻转二叉树

题目链接&#xff1a;226. 翻转二叉树 - 力扣&#xff08;LeetCode&#xff09; 就是交换两颗子树&#xff0c;二叉树都递归就行 class Solution { public:TreeNode *invertTree(TreeNode *root) {if (!root)return nullptr;swap(root->left, root->right);invertTree(…

全自动ai生成视频源码,利用AI大模型,一键生成高清短视频

MoneyPrinterTurbo-基于Python全自动ai生成视频源码&#xff0c;利用AI大模型&#xff0c;一键生成高清短视频&#xff0c;只需提供一个视频 主题 或 关键词 &#xff0c;就可以全自动生成视频文案、视频素材、视频字幕、视频背景音乐&#xff0c;然后合成一个高清的短视频。 地…

QT 线程的使用

1.头文件&#xff1a; #include<QThread> 2.在.h文件中定义全局&#xff1a; QThread* threadTraj; void threadTrajProcess();//回调函数 3.在.cpp文件中&#xff1a; threadTraj new QThread();//初始化 //连接槽函数 QObject::connect(threadTraj, &QThre…

15:00面试,15:08就出来了,技术官问我什么是K8s的命令式和声明式资源管理!

15:00面试&#xff0c;15:08就出来了&#xff0c;技术官问我什么是K8s的命令式和声明式资源管理&#xff01; Kubernetes&#xff08;通常缩写为K8s&#xff09;是一个强大的容器编排系统&#xff0c;它允许开发者和运维团队以可伸缩、灵活的方式部署和管理应用程序。在Kubern…

redis bigKey问题

bigKey的产生 1、使用String存储了大文件的二进制。 2、使用集合没有考虑到数据的规模&#xff0c;或者规模的增长。 3、哈希中冗余了大量键值对。 bigKey问题 1、操作大key时会阻塞线程&#xff1a;redis是单线程。 2、网络阻塞&#xff1a;在网络中占用大量网络流量。 …

【Java】maven对项目的拆分聚合

把mvc项目进行拆分,原来是通过包名进行分层的,现在再Maven项目里,我们可以通过Maven工具,进一步的拆分,怎么分呢? 把Dao层,Service层,Controller和View层的代码,各自拆分成一个一个的表现上独立的工程来。 拆分后的工程分别是&#xff1a;mvc-dao , mvc-service , mvc-web 三…

【示例】Spring-AOP理解

前言 本文不仅介绍Spring中AOP的几种实现方式。还整体介绍一下&#xff1a;静态代理、JDK API动态代理和CGLIB动态代理 文中示例的代码地址&#xff1a; GitHubhttps://github.com/Web-Learn-GSF/Java_Learn_Examples父工程Java_Framework_Spring 静态代理、动态代理*2 他…

c++ - 运算符重载

文章目录 一、运算符重载的关键字和注意点二、重载 运算符三、重载 运算符四、重载 运算符五、重载前置 和 后置 运算符六、重载 << >>运算符 一、运算符重载的关键字和注意点 C为了增强代码的可读性引入了运算符重载&#xff0c;运算符重载是具有特殊函数名的函…

CANFD通讯数据64字节,强制成结构体类型的做法---用C语言

在处理通信数据时&#xff0c;特别是当数据按照特定结构体的布局在网络上传输时&#xff0c;你可能需要将接收到的字节流转换为相应的结构体类型。这里是如何在C语言中强制将接收到的64字节数据转换为结构体类型的一个示例&#xff1a; #include <stdio.h> #include <…

【JavaEE】浅谈线程(一)

线程 前言线程的由来线程是什么线程的属性线程更高效的原因举个例子&#xff08;线程便利性的体现&#xff09; 多线程代码线程并发执行的代码jconsole(观测多线程) 线程的调度问题创建线程的几种方法1&#xff09;通过继承Thread 重写run2&#xff09;使用Runnable接口 重写ru…

MySQL 上亿大表,如何深度优化?

背景 分析 测试 实施 索引优化后 delete大表优化为小批量删除 总结 前段时间刚入职一家公司&#xff0c;就遇上这事&#xff01; 背景 XX实例&#xff08;一主一从&#xff09;xxx告警中每天凌晨在报SLA报警&#xff0c;该报警的意思是存在一定的主从延迟&#xff08;…

【Node】Node的配置文件的使用,dotenv框架的使用

&#x1f601; 作者简介&#xff1a;一名大四的学生&#xff0c;致力学习前端开发技术 ⭐️个人主页&#xff1a;夜宵饽饽的主页 ❔ 系列专栏&#xff1a;Node.js &#x1f450;学习格言&#xff1a;成功不是终点&#xff0c;失败也并非末日&#xff0c;最重要的是继续前进的勇…

Kotlin基础学习

学习 Kotlin 是一个很好的选择&#xff0c;它是一种现代的、静态类型的编程语言&#xff0c;旨在与 Java 和 Android 平台无缝集成&#xff0c;并提供更简洁、更安全的语法。以下是你可以开始学习 Kotlin 的基础知识的步骤&#xff1a; 了解 Kotlin 的基础语法&#xff1a; 学习…