蓝桥杯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个小时很难受,晕车症状有点严重,吃了快 ...
随机推荐
- 【新发现】不用苹果开发账号就能申请ios证书真机调试
虽然xcode现在可以免证书进行测试了,但众多跨平台开发者,如果还没注册苹果开发者账号. 想安装到自己非越狱手机测试是无能为力了. 不过新技术来了,只需要普通免费的苹果账号无需付费成为开发者就可以申请 ...
- 广搜:codevs-3344(初步bfs)
一道典型的迷宫问题 小刚在迷宫内,他需要从A点出发,按顺序经过B,C,D--,到达最后一个点,再回到A点.迷宫内有些障碍,问至少走几步. 输入描述 Input Description 第一行有三个数n ...
- pentaho之kettle篇---kettle基本操作
今天先来做一个简单的kettle的例子. 打开输入,选择CSV文件输入. 双击CSV文件输入图标,可以看见如下: 步骤名称:就是你这一步的名字,可以任意取,原则就是要明白,清楚这一步是做了什么操作. ...
- Angular2.0的项目架构
Angular2.0的项目架构 一.项目服务端app a) Controller控制器 b) Router路由 c) Service服务 d) Public公共样式及脚本和图片等静态资源 e) Vie ...
- SQL中 LEFT JOIN ,RIGHTJOIN,INNER JOIN 的使用及优先级浅析
首先了解JOIN的基本概念: join 用于根据两个或多个表中的列之间的关系,从这些表中查询数据. INNER JOIN:在表中存在至少一个匹配时,INNER JOIN 关键字返回行. LEFT JO ...
- selenium的操作JS命令的接口JavascriptExecutor的介绍
nterface JavascriptExecutor 接口 JS执行器 public interface JavascriptExecutor 表示可以执行JavaScript的驱动程序,提供对机制 ...
- rtems在mini2440上的移植(ubuntu)
第一步 建立编译环境,rtems的编译环境需要使用newlib的库,所以ubuntu自带的gcc是不可以的,我是参照下面的博客才编译成功的,之前走了好多弯路. http://blog.sina.com ...
- html table中单元格自动换行
table中单元格自动换行样式: table-layout: fixed; word-wrap: break-word; table-layout 可能的值(IE不支持inherit属性) 值 描 ...
- 我了解到的JavaScript异步编程
一. 一道面试题 前段时间面试,考察比较多的是js异步编程方面的相关知识点,如今,正好轮到自己分享技术,所以想把js异步编程学习下,做个总结. 下面这个demo 概括了大多数面试过程中遇到的问题: f ...
- 深入解析Javascript异步编程
这里深入探讨下Javascript的异步编程技术.(P.S. 本文较长,请准备好瓜子可乐 :D) 一. Javascript异步编程简介 至少在语言级别上,Javascript是单线程的,因此异步编程 ...