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

二叉树(了解)c++

二叉树是一种特殊的树型结构,它的特点是:

  • 每个结点至多只有2棵子树(即二叉树中不存在度大于2的结点)   
  • 并且二叉树的子树有左右之分,其次序不能任意颠倒,因此是一颗有序树

以A结点为例,左边的B是它的左孩子,右边的C是它的右孩子,以左孩子为根的这棵树称为左指树,以右孩子为根的这棵树称为右子树,把BDEH单独拉出来看就是一个二叉树,B是它的根结点,D H是左子树,E是右子树,同理,C这个右子树也是把CFGI单独拿出来看,C是他的根结点,FI是左子树,G是右子树,因此二叉树可以抽象为右边这个等式

  • 二叉树也是通过递归定义的结构

满二叉树:

在一棵二叉树中,所有非叶结点都存在左右孩子,所有叶子结点都在同一层,那么这棵树就是满二叉树

                           

性质:

  1. 高度为h的满二叉树,结点个数为2h-1
  2. 结点个数为n的满二叉树,树高h=log以2为底n+1
  3. 如果将满二叉树按照层序遍历的过程编号:从根节点开始,由1开始编号:
    •  结点i左孩子的编号为2xi
    • 结点i右孩子的编号为2xi+1结点i双亲的编号为i/2
    • 这个性质可以帮助我们存储二叉树 

完全二叉树

如果一棵树所有结点和同样深度的满二叉树,按照层序遍历编号的位置-一对应,则这棵二叉树为完全二叉树。(这个定义很抽象,我们可以记住相当于在满二叉树的基础上,从后往前依次删掉一些结点就变成了完全二叉树 )


http://www.kler.cn/a/517722.html

相关文章:

  • HTML-新浪新闻-实现标题-样式1
  • 粒子群算法 笔记 数学建模
  • 性能测试丨分布式性能监控系统 SkyWalking
  • JVM学习指南(48)-JVM即时编译
  • SpringBoot统一功能处理
  • ray.rllib-入门实践-11: 自定义模型/网络
  • Microsoft Edge 企业策略禁用更新
  • 【设计模式】访问者模式(Visitor Pattern): visitor.visit(), accept()
  • RocketMQ 系列文章
  • 【读书笔记·VLSI电路设计方法解密】问题43:什么是TestBench
  • python http调用视觉模型moondream
  • 配电自动化中的进线监控技术
  • 第十五届蓝桥杯大赛软件赛省赛Java 大学 B 组(1、2题)
  • git Bash通过SSH key 登录github的详细步骤
  • 微服务学习-负载均衡器 LoadBalancer 实战
  • QT QTableWidget控件 全面详解
  • 【阿里云】使用docker安装nginx后可以直接访问
  • 用wordpress搭建跨境电商独立站后没有询盘该怎么办
  • 深度解析:哪种心磁图技术是心脏检查的精准之选?
  • 【Qt 常用控件】显示类控件2(QLCDNumber、QProgressBar、QCalenderWidget)
  • 【优选算法】6----查找总价格为目标值的两个商品
  • Android OpenGL(八)转场特效
  • Java 异常处理介绍
  • OpenCV imread函数读取图像__实例详解
  • Solon Cloud Gateway 开发:Route 的过滤器与定制
  • uni-app 程序打包 Android apk、安卓夜神模拟器调试运行