头歌打印二叉树(递归里自增自减陷阱)

简介: 头歌打印二叉树(递归里自增自减陷阱)

任务描述


本关任务:请你实现 PrintTree.cpp 里的void PrintTreeRootLeft(TNode* r, int layer)函数。


相关知识


用二叉树的双指针结构存储二叉树,每个结点所含数据元素均为单个字母,试编程实现按树形状打印二叉树的算法。例如:图 1 的二叉树打印为右边的形状。


图 1 打印树结构示意图


ae683eba2b2a4905bbd426e7f48422f0.png


图 1 中的二叉树打印出来的树结构实际上是一个6行4列的矩阵,如图 2 所示。

图 2 树结构打印矩阵




b6e4e5b1d6f04b34a3fd332747248224.png

若由下往上收集结点,得到的序列刚好是该树的中序遍历序列,因此打印树结构相当于按照中序遍历序列的相反次序进行打印,每个结点打印一行;该例子中,打印出来的树结点共 4 列,与树的层数相同,每个结点在打印结果中所在的列号等于该结点在树中的层号。


为了便于看清打印结果,我们要求对于打印出的每一行,字母前的每个空格打印为“-----”,即连续5个’-‘;字母打印为形如”----A”的形式;字母后的空格不用打印。这样图 1 的树的打印结果应为:

---------C
-------------------F
--------------E
----A
--------------D
---------B


树结点结构定义为:


struct TNode{
char data;
struct TNode* left;
struct TNode* right;
};


编程要求

请你实现 PrintTree.cpp 里的void PrintTreeRootLeft(TNode* r, int layer)函数。

//PrintTree.cpp
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "PrintTree.h"
TNode* LayersToTree(char *A, int n)
/*
功能:由补充虚结点(‘^’)的层序序列构造二叉树
参数:`A`: 补充了虚结点(‘^’)的层序序列
`n`: 序列的长度
输出: 所构造的二叉树的根指针,`NULL`表示没有构造出二叉树
*/
{
TNode** pnode;
TNode* node;
int i;
if(n<=0)
return NULL;
pnode= new TNode*[n];
for(i=0; i<n; i++){
if(A[i]!='^'){
node=new TNode;
node->data=A[i];
node->left=NULL;
node->right=NULL;
pnode[i]=node;
}
else
pnode[i]=NULL;
}
for(i=0; i<n; i++){
if(pnode[i]==NULL) continue;
if(2*(i+1)<=n && pnode[2*(i+1)-1]!=NULL)
pnode[i]->left=pnode[2*(i+1)-1];
if(2*(i+1)+1<=n && pnode[2*(i+1)]!=NULL)
pnode[i]->right=pnode[2*(i+1)];
}
node=pnode[0];
delete pnode;
return node;
}
void PrintTreeRootLeft(TNode* r, int layer)
//r是树中一棵子树的根,打印以结点r为根的子树,
//layer是r在树中所处的层,约定树的根结点的层号为1
{
//在begin和end之间实现你的代码。
/******begin********/
/******end**********/
}
void DeleteTree(TNode* t)
{
if(t==NULL) return;
if(t->left) DeleteTree(t->left);
if(t->right) DeleteTree(t->right);
delete t;
}
————————————————
版权声明:本文为CSDN博主「忧伤小A」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_63499305/article/details/127587866


测试说明


本关的测试过程如下:


平台编译 step2/Main.cpp ;

平台运行该可执行文件,并以标准输入方式提供测试输入;

平台获取该可执行文件的输出,然后将其与预期输出对比,如果一致则测试通过;否则测试失败。

输入格式: 输入层序序列


输出格式: 输出打印结果


以下是平台对 step2/Main.cpp 的测试样例:


样例输入: ABD^C^E


样例输出: Print (Root Left): --------------E ---------D ----A --------------C ---------B


开始你的任务吧,祝你成功!


代码

很基础的题目,中序遍历反向即可。


void PrintTreeRootLeft(TNode* r, int layer)
//r是树中一棵子树的根,打印以结点r为根的子树,
//layer是r在树中所处的层,约定树的根结点的层号为1
{
    /*请在BEGIN和END之间实现你的代码*/
    /*****BEGIN*****/
    int i,j;
    if(r==NULL){
        return;
    }


    PrintTreeRootLeft(r->right,layer+1);//注意递归里千万不要用自增自减运算符,自增自减改变的是这个变量的值,而递归里面的增加则是将layer+1的值赋给下一个layer,对当前时空的layer是没有影响的。

for(i=0;i<5*(layer-1);i++){
        printf("-");
    }
    printf("----%c\n",r->data);
    PrintTreeRootLeft(r->left,layer+1);
    /******END******/
    /*请不要修改[BEGIN,END]区域外的代码*/
}



相关文章
|
9月前
|
缓存 API 数据安全/隐私保护
自学记录:学习HarmonyOS Location Kit构建智能定位服务
作为一名对新技术充满好奇心的开发者,我选择了HarmonyOS Next 5.0.1(API 13)作为挑战对象,深入研究其强大的定位服务API——Location Kit。从权限管理、获取当前位置、逆地理编码到地理围栏,最终成功开发了一款智能定位应用。本文将结合代码和开发过程,详细讲解如何实现这些功能,并分享遇到的挫折与兴奋时刻。希望通过我的经验,能帮助其他开发者快速上手HarmonyOS开发,共同探索更多可能性。
352 5
|
Android开发 开发者
HarmonyOS和OpenHarmony区别联系
【7月更文挑战第26天】
592 17
|
缓存 JavaScript
【Node】node.js安装与配置(详细步骤)
【Node】node.js安装与配置(详细步骤)
4365 2
|
10月前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。
|
10月前
|
算法
数据结构之卫星通信网络(BFS)
本文介绍了卫星通信网络及其重要性,并探讨了广度优先搜索(BFS)算法在其中的应用。卫星通信网络通过在轨卫星提供全球覆盖的通信服务,尤其在偏远地区和紧急救援中发挥关键作用。BFS算法用于网络拓扑分析、路径规划和故障排除,确保通信网络的高效运行。文章还包括BFS算法的工作原理、特点、优缺点及其实现代码示例。
247 1
|
11月前
|
消息中间件 监控 网络协议
Python中的Socket魔法:如何利用socket模块构建强大的网络通信
本文介绍了Python的`socket`模块,讲解了其基本概念、语法和使用方法。通过简单的TCP服务器和客户端示例,展示了如何创建、绑定、监听、接受连接及发送/接收数据。进一步探讨了多用户聊天室的实现,并介绍了非阻塞IO和多路复用技术以提高并发处理能力。最后,讨论了`socket`模块在现代网络编程中的应用及其与其他通信方式的关系。
863 3
|
机器学习/深度学习 自然语言处理 算法
【数据挖掘】百度机器学习-数据挖掘-自然语言处理工程师 2023届校招笔试详解
百度2023届校招机器学习/数据挖掘/自然语言处理工程师笔试的题目详解
212 1
|
SQL Oracle 关系型数据库
多环境数据同步(Navicat工具)
多环境数据同步(Navicat工具)
295 0
|
存储 前端开发 JavaScript
Web 身份验证:Cookie 与 Token | 8月更文挑战
应用开发一般都少不了身份验证,而身份验证机制的稳定性对所有应用程序都变得至关重要。具体选择何种方式进行身份验证可以根据项目及团队情况来衡量,在决定之前需要先理解WEB身份验证常见的两种方式:基于 Cookie 的身份验证和基于令牌(Token)的身份验证。
508 0
Web 身份验证:Cookie 与 Token | 8月更文挑战
|
分布式计算 并行计算 算法
【高并发】什么是ForkJoin?看这一篇就够了!
在JDK中,提供了这样一种功能:它能够将复杂的逻辑拆分成一个个简单的逻辑来并行执行,待每个并行执行的逻辑执行完成后,再将各个结果进行汇总,得出最终的结果数据。有点像Hadoop中的MapReduce。 ForkJoin是由JDK1.7之后提供的多线程并发处理框架。ForkJoin框架的基本思想是分而治之。什么是分而治之?分而治之就是将一个复杂的计算,按照设定的阈值分解成多个计算,然后将各个计算结果进行汇总。相应的,ForkJoin将复杂的计算当做一个任务,而分解的多个计算则是当做一个个子任务来并行执行。
6823 0
【高并发】什么是ForkJoin?看这一篇就够了!