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. "森林的层序" 恢复每个结点的孩子

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

相关推荐
代码游侠3 分钟前
ARM开发——阶段问题综述(二)
运维·arm开发·笔记·单片机·嵌入式硬件·学习
张祥64228890431 分钟前
误差理论与测量平差基础笔记十
笔记·算法·机器学习
历程里程碑3 小时前
滑动窗口---- 无重复字符的最长子串
java·数据结构·c++·python·算法·leetcode·django
云边散步4 小时前
godot2D游戏教程系列二(4)
笔记·学习·游戏开发
BORN(^-^)4 小时前
《产品经理方法论》阅读笔记
笔记·产品经理
jrlong4 小时前
DataWhale大模型基础与量化微调task4学习笔记(第 2 章:高级微调技术_RLHF 技术详解)
笔记·学习
番茄大王sc4 小时前
2026年科研AI工具深度测评(一):文献调研与综述生成领域,维普科创助手领跑学术严谨性
人工智能·深度学习·考研·学习方法·论文笔记
傻小胖4 小时前
13.BTC-思考-北大肖臻老师客堂笔记
笔记·区块链
派大鑫wink4 小时前
【Day61】Redis 深入:吃透数据结构、持久化(RDB/AOF)与缓存策略
数据结构·redis·缓存
独处东汉5 小时前
freertos开发空气检测仪之输入子系统结构体设计
数据结构·人工智能·stm32·单片机·嵌入式硬件·算法