当前位置: 首页 > ops >正文

408第一季 - 数据结构 - 树与二叉树

神秘公式

可以看见啊,每个节点都有一个向上的根的,只有顶点A没有,所以我们就有个公式

n = e + 1  n是节点个数,e的边的个数

度的概念

B度为2,D度为3,孩子个数成为节点的度

分支节点

分支节点 = 非叶子节点 = 非终端节点

度为0是孩子节点,中专结点

森林

把下面的图看成整体就是森林

性质

所有结点的度数之和(就是边的数量)加1 就是结点数

后面有一些性质不用记了,看见题目时现推一下就知道了

比如:

假设度是4

很容易就看出来了,bro

做题

1

80+30+2+10 +1 = 123个结点

就剩下度为0的没有了,度为0就是叶子节点

123-20-10-1-10= 82个叶子节点

b

2

第一个圈起来的树,结点比边多1个,第二个数也是,第三个树也是

可以看见这个森林,有n条边和n+3个节点,有3颗树

题目里是15条边,和 15加10个结点,所以啊,有10颗树

c

二叉树

完全二叉树

完全二叉树右边可以少

 也就是说

最大两层,就是倒数第二层的7,和最后一层的8,9,10,11,12

二叉树的性质

性质1

 叶子节点等于度为2的节点+1 , 怎么推的?

这里就是度为0的节点 加 度为1的节点 加 度为2的节点 等于 度为1的边 加 度为2的边(边有2个所以乘2) + 1,这里n1和n2加起来其实就是边的个数

做题

1

叽里咕噜说什么呢,其实就是满二叉树

a

2

 运用公式,可以看见叶子节点和度为2的节点有奇数个,题目里的2n就在很明确的告诉我们,总数是偶数个,因此啊,度为1的必定是奇数个

以后就可以记住了,偶数个节点啊,一定会有奇数个度为1的节点

C选择这里有说有偶数个(2m)度为1的,所以错了

3

n2可以替换为n0-1,然后n1要么是1要么是0

然后0和1都试一下,第一个解不出来,所以第二个是正确的

这里如果我们知道上面的公式就是偶数个节点啊,一定会有奇数个度为1的节点,就会知道这里一定不会为0

性质2和3

推的话就是用等比啊,没什么东西,但用的频率极高

做题

1

完全二叉树吗,有意思,来吧

注意倒数第一和倒数第二层才会出现叶子节点,又问的最多,所以第六层的8个是倒数第二层的叶子节点

所以 1(第一层)+ 2(第二层)+4(第三层)+8(第四层)+16(第五层)+32(第六层)+(32-8)*2等于111个节点

c

2

 

注意倒数第一和倒数第二层才会出现叶子节点,又问的最少,所以第六层的8个是倒数第一层的叶子节点

所以 1(第一层)+ 2(第二层)+4(第三层)+8(第四层)+16(第五层)+8(第六层)等于39个节点

a

性质4

这里第一个公式有个向上取整的符号,比如3.1就是4

第二个公式是向下取整的符号

以后的折半查找判断树要用的

存储结构

首先要是完全二叉树,因为这样就可以防止还原不唯一

然后就是链式,你得看这左边的表还原成唯一的二叉树就行了,链式存储可以不连续

做题

1

 一般人可能会这样做

但老头这招太狠了

题目里有个任意,也就是说任何树都可以,所以应该这样做(也就是最大化31个节点)

这时候就有人说了,byd那至少是干什么的,至少的意思就是说,什么32个40个存储空间就没有必要了,所以31个刚刚好

记住看见老头的任意门,要考虑最坏的情况

http://www.xdnf.cn/news/12529.html

相关文章:

  • 数 据 结 构 进 阶:哨 兵 位 的 头 结 点 如 何 简 化 链 表 操 作
  • btstack协议栈---Ubuntu驱动CSR8510 USB Dongle
  • 数学:花括号在数学中的应用详解
  • 35 C 语言字符串转数值函数详解:strtof、strtod、strtold(含 errno 处理、ERANGE 错误)
  • Ubuntu挂载本地镜像源(像CentOS 一样挂载本地镜像源)
  • 什么是高考?高考的意义是啥?
  • Ubuntu下有关UDP网络通信的指令
  • Linux 下关于 ioremap 系列接口
  • 虚幻引擎5-Unreal Engine笔记之SET节点的输出引脚获取设置后的最新变量值
  • 【力扣链表篇】19.删除链表的倒数第N个节点
  • ASTRA论文总结
  • PDF转PPT转换方法总结
  • 移除元素-JavaScript【算法学习day.04】
  • 基于Java Swing的办公自动化系统设计与实现:附完整源码与论文
  • Deepseek基座:Deepseek-v2核心内容解析
  • 【C/C++】STL实现版本为什么比手写版本高?
  • Spring Cloud 多机部署与负载均衡实战详解
  • 向 AI Search 迈进,腾讯云 ES 自研 v-pack 向量增强插件揭秘
  • 通俗解释Linux 动态库-fPIC的作用
  • Dynamics 365 Finance + Power Automate 自动化凭证审核
  • 通过 Ansible 在 Windows 2022 上安装 IIS Web 服务器
  • Python 自定义函数详解及递归函数等案例
  • 协议哨兵:场景化协议风险的ai工具
  • Tableau for mac 驱动
  • 《探秘局域网广播:网络世界的 “大喇叭”》
  • 前端 Electron 桌面应用学习笔记
  • electron-vite串口通信
  • 队列的概念及实现
  • LeetCode 高频 SQL 50 题(基础版)之 【子查询】· 上
  • (LeetCode 每日一题)3170. 删除星号以后字典序最小的字符串(贪心+栈)