蓝桥杯PREV-11:横向打印二叉树
嗯,没错我还报了蓝桥杯。
这是题目
问题描述
二叉树可以用于排序。其原理很简单:对于一个排序二叉树添加新节点时,先与根节点比较,若小则交给左子树继续处理,否则交给右子树。
当遇到空子树时,则把该节点放入那个位置。
比如,10 8 5 7 12 4 的输入顺序,应该建成二叉树如下图所示,其中.表示空白。
...|-12
10-|
...|-8-|
.......|...|-7
.......|-5-|
...........|-4本题目要求:根据已知的数字,建立排序二叉树,并在标准输出中横向打印该二叉树。
输入格式
输入数据为一行空格分开的N个整数。 N<100,每个数字不超过10000。
输入数据中没有重复的数字。
输出格式
输出该排序二叉树的横向表示。为了便于评卷程序比对空格的数目,请把空格用句点代替:
样例输入1
10 5 20
样例输出1
...|-20
10-|
...|-5样例输入2
5 10 20 8 4 7
样例输出2
.......|-20
..|-10-|
..|....|-8-|
..|........|-7
5-|
..|-4
这是分析
- 横向打印,使用中序遍历可以获得每个节点应该在的层数
- ‘|’这个符号的打印是大难点
这是我的思路
- 使用一个二维字符数组来保存所有应该打印出来的东西
- 使用中序遍历获得顺序
- 同样使用中序遍历来打印每个数字
- 对于每一个非叶节点,单独打印这个节点跟它的子节点的连线
这是代码
#include<stdio.h>
#include<stdlib.h>
#define COLS 10002
#define ROWS 102
char graph[ROWS][COLS];
struct Node
{
int lines;//这个节点应该在第几行被打印
int layer;//这个节点在第几层
int value;
struct Node *left,*right;
};
struct Node *tree;
int i_index = 0;
int j_index = 0;
int index=0;
void insert(int value)
{
int layer = 1;
int flag = 0;
struct Node *temp,*p;
if(tree==NULL){
//putchar('a');
tree = (struct Node*)malloc(sizeof(struct Node));
tree->layer = layer;
tree->value = value;
tree->right = NULL;
tree->left = NULL;
}else{
//putchar('b');
temp = tree;
while(temp!=NULL){
if(value>temp->value){
if(temp->right!=NULL)
temp = temp->right;
else{
layer++;
flag = 1;
break;
}
}else{
if(temp->left!=NULL)
temp = temp->left;
else{
layer++;
flag = 2;
break;
}
}
layer++;
}
p = (struct Node*)malloc(sizeof(struct Node));
p->left = NULL;
p->right = NULL;
p->layer = layer;
p->value = value;
if(flag==1)
temp->right = p;
else
temp->left = p;
//putchar('d');
}
//putchar('c');
}
int getLen(int n)
{
int result = 0;
while(n>0)
{
n/=10;
result++;
}
return result;
}
void inOrder(struct Node *p)
{
if(p==NULL)
return;
inOrder(p->right);
p->lines = index++;
// printf("%d:%d:%d\n",p->value,p->lines,p->layer);
inOrder(p->left);
}
void DrawFinal(struct Node *p,int j)
{
int up;int down;
int i;
if(p->right==NULL&&p->left==NULL)
return;
if(p->right==NULL)
up=p->lines;
else
up=p->right->lines;
if(p->left==NULL)
down = p->lines;
else
down=p->left->lines;
for(i = up;i<=down;i++)
graph[i][j] = '|';
}
void inOrderDraw(struct Node *p)
{
int i;
int temp = j_index;
if(p==NULL)
return ;
if(p->right!=NULL)
{
if(p->layer>1)
j_index+=3;
j_index+=getLen(p->value);
inOrderDraw(p->right);
}
j_index = temp;
/*for(i=0;i<j_index;i++)
graph[i_index][i] = '.';
*/
i = j_index;
if(p->layer!=1)
{
graph[i_index][i++] = '.';
graph[i_index][i++] = '|';
graph[i_index][i++] = '-';
}
i+= sprintf(graph[i_index]+i,"%d",p->value);
if(p->left!=NULL||p->right!=NULL)
{
graph[i_index][i++] = '-';
graph[i_index][i++] = '|';
DrawFinal(p,i-1);
}
graph[i_index][i++] = '\n';
graph[i_index][i] = '\0';
i_index++;
if(p->left!=NULL)
{
if(p->layer>1)
j_index+=3;
j_index+=getLen(p->value);
inOrderDraw(p->left);
}
}
int main()
{
int i,j;
int num;
char c;
int n=0;
for(i = 0;i<ROWS;i++)
for(j=0;j<COLS;j++)
graph[i][j] = '.';
tree = NULL;
while(1)
{
scanf("%d",&num);
c = getchar();
n++;
insert(num);
if(c=='\n')
break;
}
inOrder(tree);
inOrderDraw(tree);
for(i=0;i<n;i++)
for(j=0;graph[i][j]!='\0';j++)
putchar(graph[i][j]);
return 0;
}
感觉代码还是没有其他人的好。
但是其他人的我也没看懂。。。(:3 | ∠)
但是做出来了还是很开心的。。
蓝桥杯PREV-11:横向打印二叉树的更多相关文章
- Java实现 蓝桥杯 历届试题 横向打印二叉树
问题描述 二叉树可以用于排序.其原理很简单:对于一个排序二叉树添加新节点时,先与根节点比较,若小则交给左子树继续处理,否则交给右子树. 当遇到空子树时,则把该节点放入那个位置. 比如,10 8 5 7 ...
- 算法笔记_189:历届试题 横向打印二叉树(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 二叉树可以用于排序.其原理很简单:对于一个排序二叉树添加新节点时,先与根节点比较,若小则交给左子树继续处理,否则交给右子树. 当遇到空子树 ...
- 【蓝桥杯单片机11】单总线温度传感器DS18B20的基本操作
[蓝桥杯单片机11]单总线温度传感器DS18B20的基本操作 广东职业技术学院 欧浩源 单总线数字温度传感器DS18B20几乎成了各类单片机甚至ARM实验板的标配模块来,在蓝桥杯的往届省赛和国赛中,这 ...
- 蓝桥杯 历届试题 PREV-2 打印十字图
历届试题 打印十字图 时间限制:1.0s 内存限制:256.0MB 小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示: 对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并 ...
- Java实现 蓝桥杯VIP 算法训练 打印下述图形
算法训练 4-1打印下述图形 时间限制:1.0s 内存限制:256.0MB 问题描述 使用循环结构打印下述图形,打印行数n由用户输入.打印空格时使用"%s"格式,向printf函数 ...
- 2013第四届蓝桥杯决赛Java高职高专组题目以及解法答案
2013第四届蓝桥杯决赛Java高职高专组题目以及解法答案 不知不觉离决赛都过去一个月了,一直忙于各种事情,都忘记整理一份试题.当作回忆也好. 1. 标题:好好学习 汤姆跟爷爷来中国旅游.一天,他帮助 ...
- 算法笔记_204:第四届蓝桥杯软件类决赛真题(Java语言C组)
目录 1 好好学习 2 埃及分数 3 金蝉素数 4 横向打印二叉树 5 危险系数 6 公式求值 前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的 ...
- 第四届蓝桥杯JavaC组国(决)赛真题
解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的小朋友贴标语.他负责贴的标语是分别写在四块红纸上的四个大字:"好.好.学. ...
- 第九届蓝桥杯国赛+第二天的第11届acm省赛的总结
第九届蓝桥杯国赛+第二天的第11届acm省赛的总结 25号坐的去北京的火车,10个小时的火车,然后挤了快两个小时的地铁,最终达到了中国矿业大学旁边的订的房间.12个小时很难受,晕车症状有点严重,吃了快 ...
随机推荐
- 使用sed命令向文件中追加可变字符串
1.如何向文件追加可变字符串,有如下两种方法 sed -i '1a '$s'' filename sed -i "1a $s" filename 注意: 以上命令是假定向文件fil ...
- Orleans例子再进一步
Orleans例子再进一步 这是Orleans系列文章中的一篇.首篇文章在此 步骤 现在我想再添加一个方法,到IGrains项目内,这个方法里面有个延迟3秒,然后返回一个Task<string& ...
- java子类和父类中静态块、非静态块、构造函数的执行顺序
public class qqqq extends Parent{ public static void main(String[] args) { new Child(); } } class Pa ...
- html&css笔记(1)
本文是在阅读<head first html and css>时记下的一些需要注意的地方. 第3章 浏览器不会显示html文本中的空白符和换行. 标签的属性用来定义一个元素.p53 hre ...
- CASE WHEN 及 SELECT CASE WHEN的用法(转)
Case具有两种格式.简单Case函数和Case搜索函数. 简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END ...
- asp.net mvc 接入阿里大于 短信验证码发送
项目前端页面实例 第1步:登录阿里大于控制台 https://www.alidayu.com/center/user/account?spm=0.0.0.0.P1K1jG 第2步:创建应用 第3步:配 ...
- 【Zigbee技术入门教程-02】一图读懂ZStack协议栈的基本架构和工作机理
[Zigbee技术入门教程-02]一图读懂ZStack协议栈的基本架构和工作机理 广东职业技术学院 欧浩源 ohy3686@foxmail.com Z-Stack协议栈是一个基于任务轮询方式的操作 ...
- Maven详解(八)------ 继承和聚合
1.继承 需求场景: 有三个 Maven 工程,每个工程都依赖某个 jar 包,比如 Junit,由于 test 范围的依赖不能传递,它必然会分散在每个工程中,而且每个工程的jar 包版本可能不一致. ...
- Struts2流程分析与工具配置
1. 运行流程 请求 -- StrutsPrepareAndExecuteFilter 核心控制器 -– Interceptors 拦截器(实现代码功能 ) -– Action 的execuute - ...
- CRF技能词识别过程
最近在用CRF做未登录技能词识别,虽然艰难,但是感觉很爽,效率非常高. (1)数据准备: 选取30000行精语料作为训练数据.每一个br作为一条数据.使用已有的技能词典对数据进行无标注分词. (2)训 ...