软件22-上午题-树与二叉树1

一、树

树形结构,非线性结构

树是n个节点的有限集合。

树的定义是递归的。

1-1、树的基本概念

1、结点的度:一个结点的子树个数。

2、树的度:树中最大的结点的度数。

3、叶子结点:度为0的结点。

4、分支结点:度不为0的结点。

5、树的高度(深度):一棵树的最大层数。

1-2、树的性质

性质1:树中的结点总数 = 树中所有结点的度数之和 + 1

出题格式:

已知,度为1的结点个数为n1;度为2的结点个数为n2;度为3的结点个数为n3,求度为0的结点个数。

性质2:度为 m 的树中第i层上至多有 m^(i-1)个结点(i >= 1)。

性质3:高度为h的m次树,至多个结点。(等比数列求和)

性质4:具有n个结点、度为m的树的最小高度为:

要求树的高度最小、需要每个结点的度都是m。即 n = 

注意:

要取上界!!!

1-3、真题

真题1:

真题2:

注意:

        这种类型的题目可以直接画个示图,举例子算。

二、二叉树

2-1、二叉树的定义

二叉树是n个结点的有限集合。

二叉树可以是空树。

二叉树、树的区别:

二叉树中结点的子树要区分左子树和右子树。

二叉树结点最大的度=2。

2-2、二叉树的性质

性质1:二叉树第i层上最多有2^(i-1)个结点;

树的性质:度为 m 的树中第i层上至多有 m^(i-1)个结点(i >= 1)。

性质2:高度为h的二叉树最多有个结点。

树的性质:高度为h的m次树,至多个结点。(等比数列求和)

性质3:对于任何一个二叉树,度为0的结点数 = 度为2的结点数 + 1;

n0 = n2 + 1

树的性质: 树中的结点总数 = 树中所有结点的度数之和 + 1

性质4:具有n个结点的完全二叉树的高度为:

树的性质: 具有n个结点、度为m的树的最小高度为:

2-3、满二叉树、完全二叉树

2-3-1、满二叉树

高度为k的二叉树有2^k-1个结点。

2-3-2、完全二叉树

对满二叉树中的结点连续编号,自上而下,自左而右,每一个结点与满二叉树中的序号一一对应。

完全二叉树的特点:

  • 高度为h的完全二叉树中,除了第h层(最后一层),其余各层都是满的;
  • 第h层上的结点必须是从左到右的依次放置,不能为空。

完全二叉树的性质:

 性质4:具有n个结点的完全二叉树的高度为:

 2-4、真题

真题1:

真题2:

n0 = n2 + 1 

真题3:

真题4:

真题5:

真题6:

计算n个结点的二叉树有多少种,可以用: 

真题7:

2-5、二叉树的存储结构

2-5-1、二叉树的顺序存储

用一组地址连续的存储单元存储二叉树中的结点,结点在这个序列中的相应位置能反映出节点之间的逻辑关系。

依据二叉树的性质,完全二叉树满二叉树采用顺序存储比较合适,树中结点的序号可以唯一地反映出结点之间的逻辑关系。

 对于一般的二叉树,只有增添一些并不存在的空结点,使之成为一棵完全二叉树的形式,然后再用一维数组顺序存储。会造成空间的大量浪费,不宜用顺序存储结构。 

最坏的情况是右单支树。

从一个结点的编号——>双亲、左孩子、右孩子

 

2-5-2、二叉树的链式存储

二叉链表的结点:

 

二叉链表,有n个结点,就有2n个指针域;有n-1个分支,就有n-1个有效指针域;

所以,二叉链表,n个结点,有n+1个空指针域

三叉链表的结点:

三叉链表,n个结点,有n+2个空指针域

2-5-3、真题

真题1:

 

真题2:

真题3:

真题4:

2-6、二叉树的遍历

1、先序遍历

根节点、左子树、右子树

A  B  D  G  C  E  F

2、中序遍历

左子树、根节点、右子树

B  D  G  A  E  C  F

3、后序遍历

左子树、右子树、根节点

G  D  B  E  F  C  A

4、层次遍历

从上到下、从左到右的访问结点。

A  B  C  D  E  F  G

 

2-7、根据遍历序列构造二叉树

4种遍历,单独看,都不能唯一确定一个二叉树。

其中最重要的是:中序遍历:左子树、根节点、右子树

1、先序遍历 + 中序遍历

从先序中得到每个子树的根节点(第一个节点),在中序中用根节点,划分出左右子树。

2、后序遍历 + 中序遍历

从后序中得到每个子树的根节点(最后一个节点),在中序中用根节点,划分出左右子树。

3、层次遍历 + 中序遍历

 

4、真题

真题1:

构造一个二叉树,中序序列一定要有!!!

真题2:

真题3:

真题4:

 

真题5:

真题6:

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

this指针详细总结 | static关键字 | 静态成员

文章目录 1.this指针引入2.this指针的特性3.静态成员3.1.C语言中static的基本用法3.2.C中的static关键字 1.this指针引入 class student { public:student(const string& name){ _name name; }void print(){// _name<>this->_name<>(*this)._name// 说一下…

多路服务器技术如何处理大量并发请求?

在当今的互联网时代&#xff0c;随着用户数量的爆炸性增长和业务规模的扩大&#xff0c;多路服务器技术已成为处理大量并发请求的关键手段。多路服务器技术是一种并行处理技术&#xff0c;它可以通过多个服务器同时处理来自不同用户的请求&#xff0c;从而显著提高系统的整体性…

零基础学Python(7)— 基本输入与输出

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。从第一个Python程序开始&#xff0c;我们一直在使用print()函数向屏幕上输出一些字符&#xff0c;这就是Python的基本输出函数。除了print()函数&#xff0c;Python还提供了一个用于进行标准输入的input()函数&#xff0c;…

成员对象与封闭类

1. 成员对象与封闭类 类里有其他对象则该对象叫成员对象&#xff1b;有成员对象的类叫 封闭类&#xff1b;上例中&#xff0c;如果CCar类不定义构造函数&#xff0c;则会使用默认的无参构造函数&#xff0c;那么下面的语句会编译出错: 因为编译器不明白CCar类中的tyre成员对象…

node.js后端+小程序前端+mongoDB(增删改查)

前言 今天我对比了以下node.js的express与python的fastAPI&#xff0c;我决定我还是出一期关于node.jsmangoDB小程序的小案例吧。 不是python的fastAPI不好用&#xff0c;因为fastAPI是python较新的技术&#xff0c;我不敢果断发出教学文章&#xff08;这件事情还是留着给pyt…

《幻兽帕鲁》攻略:0基础入门及游戏基础操作 幻兽帕鲁基础设施 幻兽帕鲁基础攻击力 Mac苹果电脑玩幻兽帕鲁 幻兽帕鲁加班加点

今天就跟大家聊聊《幻兽帕鲁》攻略&#xff1a;0基础入门及游戏基础操作。 如果想在苹果电脑玩《幻兽帕鲁》记得安装CrossOver哦。 以下纯干货&#xff1a; CrossOver正版安装包&#xff08;免费试用&#xff09;&#xff1a;https://souurl.cn/Y1gDao 一、基础操作 二、界面…

生成式学习,特别是生成对抗网络(GANs),存在哪些优点和缺点,在使用时需要注意哪些注意事项?

生成对抗网络&#xff08;GANs&#xff09; 1. 生成对抗网络&#xff08;GANs&#xff09;的优点&#xff1a;2. 生成对抗网络&#xff08;GANs&#xff09;的缺点&#xff1a;3. 使用生成对抗网络&#xff08;GANs&#xff09;需要注意的问题 1. 生成对抗网络&#xff08;GANs…

RabbitMQ的延迟队列实现[死信队列](笔记二)

上一篇已经讲述了实现死信队列的rabbitMQ服务配置&#xff0c;可以点击: RabbitMQ的延迟队列实现(笔记一) 目录 搭建一个新的springboot项目模仿订单延迟支付过期操作启动项目进行测试 搭建一个新的springboot项目 1.相关核心依赖如下 <dependency><groupId>org.…

设计模式理解:单例模式+工厂模式+建设者模式+原型模式

迪米特法则&#xff1a;Law of Demeter, LoD, 最少知识原则LKP 如果两个软件实体无须直接通信&#xff0c;那么就不应当发生直接的相互调用&#xff0c;可以通过第三方转发该调用。其目的是降低类之间的耦合度&#xff0c;提高模块的相对独立性。 所以&#xff0c;在运用迪米特…

【机器学习】机器学习流程之收集数据

&#x1f388;个人主页&#xff1a;甜美的江 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;机器学习 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步…

有趣的CSS - 旋转的太极图

目录 整体效果核心代码html 代码css 部分代码 完整代码如下html 页面css 样式页面渲染效果 整体效果 使用 :before 、:after 伪元素以及 animation 属性画一个顺时针旋转的太极图。 核心代码部分&#xff0c;简要说明了写法思路&#xff1b;完整代码在最后&#xff0c;可直接复…

PKI - 03 密钥管理(如何进行安全的公钥交换)

文章目录 Pre密钥管理面临的挑战安全密钥管理的几种方式手动密钥交换与确认受信任的介绍 Pre PKI - 02 对称与非对称密钥算法 密钥管理面临的挑战 密钥管理面临的挑战主要包括以下几点&#xff1a; 安全的公钥交换&#xff1a;在使用基于非对称密钥算法的服务之前&#xff0c…

Hadoop3.x基础(4)- Yarn

来源&#xff1a;B站尚硅谷 目录 Yarn资源调度器Yarn基础架构Yarn工作机制作业提交全过程Yarn调度器和调度算法先进先出调度器&#xff08;FIFO&#xff09;容量调度器&#xff08;Capacity Scheduler&#xff09;公平调度器&#xff08;Fair Scheduler&#xff09; Yarn常用命…

回归预测 | Matlab实现ABC-BP人工蜂群算法优化BP神经网络多变量回归预测

回归预测 | Matlab实现ABC-BP人工蜂群算法优化BP神经网络多变量回归预测 目录 回归预测 | Matlab实现ABC-BP人工蜂群算法优化BP神经网络多变量回归预测预测效果基本描述程序设计参考资料 预测效果 基本描述 1.Matlab实现ABC-BP人工蜂群算法优化BP神经网络多变量回归预测&#x…

盘点Java集合(容器)概览,Collection和Map在开发中谁用的最多?

写在开头 在Java的世界里万物皆对象。但我认为是万物皆数据&#xff0c;世界由各种各样数据构建起来&#xff0c;我们通过程序去实现数据的增删改查、转入转出、加减乘除等等&#xff0c;不同语言的实现方式殊途同归。由此可见&#xff0c;数据对于程序语言的重要性。 这段话…

Spring Boot 001 环境配置以及初始化项目

知识储备 后端&#xff1a;JavaSE, SSM&#xff08;SpringSpringMVCMyBatis&#xff09; 前端&#xff1a;HTML, CSS, Javascript 环境准备 JDK17下载 Java Downloads | Oracle 安装方式 JDK17在Windows安装以及环境变量配置&#xff08;超详细的教程&#xff09;_jdk17安装…

功能强大的国外商业PHP在线教育系统LMS源码,直播课程系统

源码介绍 Proacademy是在线教育一体化的解决方案&#xff0c;用于创建类似于Udemy、Skillshare、Coursera这种在线教育市场。 这个平台提供在线课程&#xff0c;现场课程&#xff0c;测验等等&#xff0c;并有一个基于实际业务需要的高级认证插件&#xff0c;程序基于Laravel…

NLP中的嵌入和距离度量

本文将深入研究嵌入、矢量数据库和各种距离度量的概念&#xff0c;并提供示例和演示代码。 NLP中的嵌入 嵌入是连续向量空间中对象、单词或实体的数值表示。在NLP中&#xff0c;词嵌入捕获词之间的语义关系&#xff0c;使算法能够更好地理解文本的上下文和含义。 让我们试着用…

国考省考行测:平行结构体

国考省考行测&#xff1a;平行结构体 2022找工作是学历、能力和运气的超强结合体! 公务员特招重点就是专业技能&#xff0c;附带行测和申论&#xff0c;而常规国考省考最重要的还是申论和行测&#xff0c;所以大家认真准备吧&#xff0c;我讲一起屡屡申论和行测的重要知识点 遇…

微信小程序(三十七)选项点击高亮效果

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.选择性渲染类 2.以数字为需渲染内容&#xff08;数量&#xff09; 源码&#xff1a; index.wxml <view class"Area"><!-- {{activeNumindex?Active:}}是选择性添加类名进行渲染 -->&l…