蓝桥杯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个小时很难受,晕车症状有点严重,吃了快 ...
随机推荐
- linux下安装log4cplus
wget http://sourceforge.net/projects/log4cplus/files/log4cplus-stable/1.1.2/log4cplus-x.x.x.tar.gz t ...
- C# 调用C++ 结构体示例
C++ 定义 typedef struct Stu{public: int Age; char Name[20];}; typedef struct Num { int N1; int N2; }; ...
- c++类大小问题
1.空类 class A { }; 解析:类的实例化就是为每个实例在内存中分配一块地址:每个类在内存中都有唯一的标识,因此空类被实例化时,编译器会隐含地为其添加一个字节,以作区分. 2.虚函数类 cl ...
- 最新eclipse国内镜像站,比ustc等站点资源新。
http://mirrors.neusoft.edu.cn/ 东软信息学院的镜像站,上面可以看到同步时间和状态很不错. 之前为了找最新的镜像站下载babel_language_packs r0.15. ...
- Writing A Threadpool in Rust
文 Akisann@CNblogs / zhaihj@Github 本篇文章同时发布在Github上:https://zhaihj.github.io/writing-a-threadpool-in- ...
- Ubuntu与Centos在登陆安全方面的比较
Ubuntu在安装时创建的普通用户默认具有sudo权限,默认root没有设置密码,可以通过自建用户来执行sudo passwd 为root设置密码;Centos在安装时创建的普通用户默认没有sudo权 ...
- WeQuant交易策略—简单均线
简单双均线策略(Simple Moving Average) 策略介绍简单双均线策略,通过一短一长(一快一慢)两个回看时间窗口收盘价的简单移动平均绘制两条均线,利用均线的交叉来跟踪价格的趋势.这里说的 ...
- linux shell 之终端读写文件数据流和重定向>,<,<<,>>
终端实现文件中数据流的读写: 重定向命令列表如下: 命令 说明 command > file 将输出重定向到 file.将终端数据写到文件file中 command < file 将输入重 ...
- MyEclipse简介
- Java内存原型分析
Java虚拟机内存原型 寄存器:在程序中无法控制 栈:存放基本类型的数据和对象的引用,但是对象本身不存放在栈中,而是存放在堆中 堆:存放用new产生的数据 静态域:存放在对象中用static定义的静态 ...