【数据结构】使用先序递归过程构建并打印二叉树
创作时间:
作者:
@小白创作中心
【数据结构】使用先序递归过程构建并打印二叉树
引用
CSDN
1.
https://blog.csdn.net/yuzexuan666/article/details/138261711
二叉树是一种重要的数据结构,在计算机科学中有着广泛的应用。本文将介绍如何使用先序递归过程构建二叉树,并使用凹入法打印二叉树。
一、基础知识
1.1 什么是二叉树
二叉树是一种树形数据结构,其中每个节点最多有两个子节点,通常称为左子节点和右子节点。二叉树可以是空树,也可以由一个根节点加上两棵分别称为左子树和右子树的二叉树组成。
1.2 先序遍历
先序遍历是二叉树的一种遍历方式,其遍历顺序为:根节点 -> 左子树 -> 右子树。在先序遍历中,根节点总是第一个被访问。
二、题目要求
使用先序递归过程建立二叉树(存储结构:二叉链表),并用凹入法打印。输入数据按照先序遍历所得序列输入,当某节点左子树或右子树为空时,输入“ * ”号。如输入ABCDE** 得到的二叉树为:
三、实现效果
先序序列:ABCDE**
先序序列:ABCDEFGHIJK
四、代码实现
4.1 先序构建二叉树
BTNODE* CreateBiTree(void)
{
char ch;
scanf_s("%c", &ch);
if (ch == '*') // 如果读入的是 '*',表示该节点为空
return NULL;
BTNODE* T = (BTNODE*)malloc(sizeof(BTNODE));
T->data = ch; // 将读入的字符赋值给当前节点的数据域
T->lc = CreateBiTree(); // 递归创建左子树
T->rc = CreateBiTree(); // 递归创建右子树
return T;
}
这段代码实现了通过先序遍历序列构建二叉树的功能。首先读取一个字符,如果读入的是“*”,则表示该节点为空,返回NULL。否则,创建一个新的节点,将读入的字符赋值给该节点的数据域,然后递归地创建左子树和右子树。
4.2 凹入法打印二叉树
void PrintTabTab(BTNODE* T, int depth)
{
if (T)
{
for (int i = 0; i < depth; i++)
printf("__"); // 根据深度打印相应数量的缩进
printf("%c\n", T->data); // 打印当前节点的数据
PrintTabTab(T->lc, depth + 1); // 递归打印左子树,深度加1
PrintTabTab(T->rc, depth + 1); // 递归打印右子树,深度加1
}
}
这段代码实现了使用凹入法打印二叉树的功能。通过递归的方式,根据节点的深度打印相应数量的缩进,然后打印节点的数据。这样可以直观地展示二叉树的结构。
五、递归过程演示
以先序序列 ABCDE** 为例,演示递归构建二叉树的全过程:
- 读取字符 'A',创建根节点 A
- 递归创建左子树:
- 读取字符 'B',创建节点 B
- 递归创建 B 的左子树:
- 读取字符 'C',创建节点 C
- 读取字符 '*',表示 C 的左子树为空
- 读取字符 '*',表示 C 的右子树为空
- 读取字符 '*',表示 B 的右子树为空
- 递归创建 A 的右子树:
- 读取字符 'D',创建节点 D
- 读取字符 '*',表示 D 的左子树为空
- 读取字符 'E',创建节点 E
- 读取字符 '*',表示 E 的左子树为空
- 读取字符 '*',表示 E 的右子树为空
最终构建的二叉树结构如下:
本文介绍了如何使用先序递归过程构建二叉树,并使用凹入法打印二叉树。通过具体的代码示例和递归过程演示,帮助读者理解二叉树的构建和打印算法。
本文原文来自CSDN
热门推荐
情智语文:孙双金的情感体验与审美教育
AGA与金丰来大揭秘,智能科技让黄金产业带来哪些变革
考研全攻略:目标设定、资料挑选、时间管理及心态调整技巧
海鸥的养育环境
视觉传达设计专业就业前景:2025年高考生必看的“金饭碗”指南
职称广东省:深度解析建筑行业与工程类职称评审全攻略
探索中国人祖先起源未解之谜
《伤寒论》辨证体系与经方速记指南
销售管理如何反思问题
如何理解资产的分类?这类分类有什么财务意义?
英语口语进阶指南:掌握发音技巧,提升听讲实战能力
喉咙辣辣的有烧灼感是咋回事
关于禅的入门,这5本书值得一读
深圳工业废水检测污染以及排放标准
大学生普通话对话:提升语言能力与交流技巧的实践探讨
年轻人高发的甲状腺结节,会癌变吗?
养小乌龟的方法和技巧
生命的意义到底是什么?为什么生命一定会死亡而不能永生?
《西游记》狮驼岭原型尸陀林有多恐怖,万人墓坑尸骨林立!
如何进行理性的股票投资操作?这种操作的技巧和方法有哪些?
追忆崇明四大古镇之——城桥镇篇(追忆消失的崇明古镇)
餐饮行业有哪些职业可以选择
“国补”首次扩围,利好之下手机数码厂商们将如何应对?
无故哭泣:隐藏在眼泪背后的情感失控与内心呼救
如何有效安慰哭泣的人?提供情感支持与心理抚慰的方法
大股东控制对公司发展的影响与分析
电热水器:24小时开着费电,还是“即用即开”费电?我们都错了!
量子计算新突破!科学家用“半光子”实现远程量子纠缠,距离实用仅一步之遥
牙线单双线区别及使用建议
网络负面舆情传导发酵的风险应对措施