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

代码随想录算法训练营(二叉树总结篇)

一.二叉树的种类

1.满二叉树:就是说每一个非叶子节点的节点都有两个子节点。

 2.完全二叉树:此二叉树只有最后一层可能没填满,并且存在的叶子节点都集中在左侧!!!

 (满二叉树也是完全二叉树)

3.二叉搜索树(BST树):顾名思义,搜索是跟值相关联。

  • 中间节点的左侧子树的所有节点的元素值小于中间节点的值

  • 中间节点的右侧子树的所有节点的元素值大于中间节点的值

 

 4.平衡二叉搜索树(AVL树):是一种既是平衡二叉树又是二叉搜索树的数据结构。它的每个节点的左子树和右子树的高度差不超过1,并且满足二叉搜索树的性质。

 

 注意:空树是满二叉树、平衡二叉树、二叉搜索树、平衡二叉搜索树的特例。

 二.二叉树的存储方式

1.链式存储

2.数组存储

 三.二叉树的遍历方式

1.深度优先遍历

前序遍历(中左右)

中序遍历(左中右)

后序遍历(左右中)

2.广度优先遍历

层序遍历(队列)

四.二叉树的定义

struct TreeNode{int val;TreeNode*left;TreeNode*right;TreeNode(){val=0;left=nullptr;right=nullptr;}TreeNode(int _val){val=_val;left=nullptr;right=nullptr;}
}

五.总结

  • 1.涉及二叉树的问题,首先仔细审题,判断遍历顺序
  • 2.其次根据思路写出伪代码
  • 3.根据伪代码进行修改
http://www.lryc.cn/news/128421.html

相关文章:

  • 华为开源自研AI框架昇思MindSpore应用案例:基于MindSpore框架的UNet-2D案例实现
  • Python入门【TCP建立连接的三次握手、 TCP断开连接的四次挥手、套接字编程实战、 TCP编程的实现、TCP双向持续通信】(二十七)
  • React笔记-React入门
  • SD WebUI 扩展:prompt-all-in-one
  • Go和Java实现中介者模式
  • CentOS系统环境搭建(十五)——CentOS安装Kibana
  • 简单的洗牌算法
  • vscode用ssh远程连接linux
  • chapter 3 Free electrons in solid - 3.2 量子自由电子理论对一些现象的解释
  • vue实现打印功能
  • golang—面试题大全
  • Spring、Springboot、SpringCloud--包含的知识点大全
  • MongoDB:数据库初步应用
  • C#之枚举中的按位与()按位或(|)。
  • Blazor前后端框架Known-V1.2.12
  • bug记录:微信小程序 给button使用all: initial重置样式
  • 【计算机视觉|生成对抗】带条件的对抗网络进行图像到图像的转换(pix2pix)
  • [时序数据库]:InfluxDB进阶
  • uniapp编写微信小程序遇到的坑总结
  • Binary operator ‘*‘ cannot be applied to two ‘Double?‘ operands
  • C#如何打包EXE程序生成setup安装文件
  • 【python实现向日葵控制软件功能】手机远程控制电脑
  • 手机系统录屏怎么录?有什么其他录制方法和注意事项?
  • 记录一个编译TubeTK时的报错:at_check问题
  • k8s v1.27.4二进制部署记录
  • C# API 文档注释规范
  • 分类预测 | Matlab实现基于TSOA-CNN-GRU-Attention的数据分类预测
  • 《深度剖析K8s》学习笔记
  • 神经网络基础-神经网络补充概念-49-adam优化算法
  • Java:正则表达式书写规则及相关案例:检验QQ号码,校验手机号码,邮箱格式,当前时间