05-5.4.2 树、森林和二叉树的转换

👋 Hi, I'm @Beast Cheng

👀 I'm interested in photography, hiking, landscape...

🌱 I'm currently learning python, javascript, kotlin...

📫 How to reach me --> 458290771@qq.com


喜欢《数据结构》部分笔记的小伙伴可以订阅专栏,今后还会不断更新。🧑‍💻

感兴趣的小伙伴可以点一下订阅、收藏、关注!🚀

谢谢大家!🙏

树 转 二叉树

转换技巧:

  1. 先在二叉树中,画一个根结点
  2. "树的层序" 依次处理每个结点(也就是 A − > B , C − > D , H , F , E , J , K − > G , I , L A->B,C->D,H,F,E,J,K->G,I,L A−>B,C−>D,H,F,E,J,K−>G,I,L
    处理一个结点的方法是:如果当前处理的结点在树中有孩子,就把所有孩子结点"用右指针串成糖葫芦",并在二叉树中把第一个孩子挂在当前结点的左指针下方

森林 转 二叉树

注意:森林中各棵树的根结点视为评级的兄弟关系

转换技巧:

  1. 先把所有的树的根结点画出来,再在二叉树中用右指针 串成糖葫芦
  2. "森林的层序" 依次处理每个结点

处理一个结点的方法是:如果当前处理的结点在树中有孩子,就把所有孩子结点"用右指针串成糖葫芦",并在二叉树中把第一个孩子挂在当前结点的左指针下方

二叉树 转 树

转换技巧:

  1. 先画出树的根结点
  2. 从树的根结点开始,按 "树的层序" 恢复每个结点的孩子

如何恢复一个结点的孩子:在二叉树中,如果当前处理的结点有左孩子,就把左孩子和 "一整串右指针糖葫芦" 拆下来,按顺序挂在当前结点的下方

二叉树 转 森林

转换技巧:

  1. 先把二叉树的根结点和 "一整串右指针糖葫芦" 拆下来,作为多棵树的根结点
  2. "森林的层序" 恢复每个结点的孩子

如何恢复一个结点的孩子:在二叉树中,如果当前处理的结点有左孩子,就把左孩子和 "一整串右指针糖葫芦" 拆下来,按顺序挂在当前结点的下方

相关推荐
Codigger官方8 小时前
Phoenix 语言起步指南:开启 Polyglot Singularity 之门
开发语言·人工智能·程序人生
码途漫谈8 小时前
Easy-Vibe开发篇阅读笔记(十二)——后端开发之如何集成Stripe等收费系统
笔记·ai·开源·状态模式·ai编程
在下_诸葛8 小时前
langgraph学习笔记
笔记·python·学习·langgraph教程
yue2004038 小时前
Spring IoC 与 DI 核心概念与原理笔记
java·笔记·spring
码途漫谈9 小时前
Easy-Vibe开发篇阅读笔记(十三)——附录之用 Dify 搭建知识库问答系统
笔记·ai·开源·ai编程
十安_数学好题速析9 小时前
【多选】成比之道:巧解三角形中比例综合
笔记·学习·高考
Gin3879 小时前
头歌编译原理实验1《 第1关:词法分析程序设计与实现》
笔记
skilllite作者9 小时前
Warp 新手极速上手与部署指南
java·前端·笔记·安全·agentskills
木木_王9 小时前
嵌入式Linux学习 | 数据结构(Day06)全解:线性表 + 栈队列 + 静态库 / 动态库(原理 + 代码 + 编译实战 + 易错点)
linux·数据结构·笔记·学习
-Springer-9 小时前
STM32 学习 —— 个人学习笔记11-2(SPI 通信外设 & 硬件 SPI 读写 W25Q64)
笔记·stm32·学习