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

c语言——二叉树

一、树

1.常见概念

节点的度:一个节点含有的子树的个数称为该节点的度;如上图:A的为6
叶节点或终端节点:度为0的节点称为叶节点;如上图:B、C、H、I.等节点为叶节点
非终端节点或分支节点:度不为0的节点;如上图:D、E、F、G.等节点为分支节点
双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点;如上图:A是B的父节点
孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点;如上图:B是A的孩子节点
兄弟节点:(亲兄弟)具有相同父节点的节点互称为兄弟节点;如上图:B、C是兄弟节点
树的度:一棵树中,最大的节点的度称为树的度;如上图:树的度为6
节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;
树的高度或深度:树中节点的最大层次;如上图:树的高度为4(空树的高度为0)
节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先
子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙
森林:由m(m>0)棵互不相交的多颗树的集合称为森林;(数据结构中的学习并查集本质就是一个森林)

2.树的表示

①顺序表存孩子的指针

struct TreeNode { int data; vector <struct TreeNode*> childs; };

②左孩子右兄弟

typedef int DataType; struct Node { struct Node* _firstChild1; //第一个孩子节点 struct Node* _pNextBrother; //指向其下一个兄弟节点 DataType _data; //节点中的数据域 };

③双亲表示法

用数组存父节点的下标

3.树在实际中的运用

表示文件系统的目录树结构

二、二叉树

1.概念

一棵二叉树是结点的一个有限集合,该集合或者为空,或者是由一个根节点加上两棵别称为左子树和右子树的二叉树组成。

2.特点

①每个结点最多有两棵子树,即二叉树不存在度大于2的结点。
②二叉树的子树有左右之分,其子树的次序不能颠倒。

3.任何一颗二叉树都有三个部分

①根节点
②左子树
③右子树

分治算法:分而治之,大问题分成类似子问题,子问题再分成子问题……直到子问题不可再分割

前序(先根遍历):根、左子树、右子树(根在前面)

A B D NULL NULL E NULL NULL C NULL NULL

中序(中根遍历):左子树、根、右子树(根在中间)

NULL D NULL

后序(后序遍历):左子树、右子树、根

http://www.cnnetsun.cn/news/144306.html

相关文章:

  • 收藏!从零到实战:30天AI大模型系统学习指南(小白/程序员专属)
  • Material Files:Android文件管理的终极解决方案
  • 递归与分治算法
  • grex:从测试用例到正则表达式的智能转换引擎
  • TenSunS多云管理终极指南:构建自动化运维完整解决方案
  • Sharik终极指南:简单快速的文件共享解决方案
  • FaceFusion能否实现情绪迁移?快乐、悲伤表情自动切换
  • 5分钟搞定:用YOLOv9打造智能家居行为感知系统
  • GODEL:微软开源的目标导向对话AI终极指南
  • 14、Python文件与进程操作全解析
  • 22、Python 在 Windows 上的线程编程全解析
  • Piper开发调试全攻略:告别繁琐安装,拥抱高效迭代
  • 33、服务性能优化技术全解析
  • Vuls并发处理优化:Goroutine调度与并行扫描技术解析
  • 如何用TensorFlow模型库实现零代码AI应用?
  • 终极指南:用Keil Assistant在VS Code中高效开发ARM项目
  • Qwen2-VL-2B-Instruct:如何用20亿参数重新定义多模态AI边界?
  • 破局之道:软件测试流程创新的五大战略支点
  • FaceFusion在互动电影中的角色切换创新玩法
  • 计算机毕设Java基于Java大学生考研服务系统 基于Java的大学生考研服务平台设计与实现 Java技术驱动的大学生考研服务系统开发
  • 视频实时防抖阶段总结-20251218
  • Keploy Serverless测试实践:突破无服务器架构的测试瓶颈
  • 终极快速上手:免费体验uni-app跨平台开发完整教程
  • 全面解析Mender:构建可靠的嵌入式Linux OTA更新方案
  • 彻底告别Reor快捷键冲突:让AI笔记操作得心应手
  • 终极指南:如何用openapi-typescript实现API类型安全
  • FaceFusion能否用于宠物拟人化?猫狗脸部动画生成
  • Sublime Text Markdown Preview插件:5个高效写作技巧让你的文档更专业
  • M3-Agent-Control:重新定义多智能体协作的技术革命
  • 19、数据驱动工作流与 WF RuleSet 实战指南