Trees on the level UVA - 122
Trees are fundamental in many branches of computer science (Pun definitely intended). Current stateof-the art parallel computers such as Thinking Machines’ CM-5 are based on fat trees. Quad- and octal-trees are fundamental to many algorithms in computer graphics. This problem involves building and traversing binary trees.
Given a sequence of binary trees, you are to write a program that prints a level-order traversal of each tree. In this problem each node of a binary tree contains a positive integer and all binary trees have have fewer than 256 nodes.
In a level-order traversal of a tree, the data in all nodes at a given level are printed in left-to-right order and all nodes at level k are printed before all nodes at level k+1.
For example, a level order traversal of the tree on the right is: 5, 4, 8, 11, 13, 4, 7, 2, 1.
In this problem a binary tree is specified by a sequence of pairs ‘(n,s)’ where n is the value at the node whose path from the root is given by the string s. A path is given be a sequence of ‘L’s and ‘R’s where ‘L’ indicates a left branch and ‘R’ indicates a right branch. In the tree diagrammed above, the node containing 13 is specified by (13,RL), and the node containing 2 is specified by (2,LLR). The root node is specified by (5,) where the empty string indicates the path from the root to itself. A binary tree is considered to be completely specified if every node on all root-to-node paths in the tree is given a value exactly once.
Input
The input is a sequence of binary trees specified as described above. Each tree in a sequence consists of several pairs ‘(n,s)’ as described above separated by whitespace. The last entry in each tree is ‘()’. No whitespace appears between left and right parentheses.
All nodes contain a positive integer. Every tree in the input will consist of at least one node and no more than 256 nodes. Input is terminated by end-of-file.
Output
For each completely specified binary tree in the input file, the level order traversal of that tree should be printed. If a tree is not completely specified, i.e., some node in the tree is NOT given a value or a node is given a value more than once, then the string ‘not complete’ should be printed.
Sample Input
(11,LL) (7,LLL) (8,R)
(5,) (4,L) (13,RL) (2,LLR) (1,RRR) (4,RR) ()
(3,L) (4,R) ()
Sample Output
5 4 8 11 13 4 7 2 1
not complete
HINT
这个题目可以不适用二叉树,可以使用map排序来解决,但学到数据结构了就使用二叉树来解决的。
程序设计思路是每行进行读取,然后读取这一行中的内容,直到遇到()结束这一组数据。用指针数组来存储数据。只要遇到一组数据就插入到二叉树里面,如果二叉树对应的结点已经插入了数据,就输出错误,如果二叉树查找对应结点的时候遇到了中间还没有插入的结点,那么就先建立一个空的结点,存储的数据string num的大小为0,(不为0说明已经存入了数据)。输出采用的是层序遍历,当发现有结点的数据域的长度为0那么就说明这个点没有插入输出错误。
这个题目程序有很多细节需要注意,针对自己的程序的总结如下:
- 使用 new后一定要初始化结点。
- 每次输出结果都要将二叉树删除,并将头指针指空。
- 删除结点递归的时候一定要先判断左右孩子是否为空,先序遍历也一样。
Accepted
#include<iostream>
#include<algorithm>
#include<string>
#include<vector>
#include<sstream>
using namespace std;
struct TREE{
string num;
TREE* right;
TREE* lift;
};
void remove(TREE* head){ //删除结点空间
if (!head)return;
if(head->lift) remove(head->lift);
if(head->right) remove(head->right);
delete(head);
}
bool insert(TREE* head, string var, string s) { //插入
TREE* p = head,*temp;
for (int i = 0;i < s.size()-1;i++) {
temp = s[i] == 'R' ? p->right : p->lift;
if (temp==NULL){
temp = new TREE; //如果是空的就申请空间
temp->lift = temp->right = NULL;
}
if (s[i] == 'R')p->right = temp;
else p->lift = temp;
p=temp; //向下指
}
if (p->num.size())return 0;
else { p->num = var;return 1; }
}
void print(TREE* head) { //首先层序遍历,然后输出,以内要先判断是否合法
vector<TREE *>list; //因为不需要边输出边层序遍历,所以不用使用队列
int i = 0;
if(head) list.push_back(head);
while (i++ < list.size()) { //遍历
if (!list[i-1]->num.size()) { cout << "not complete" << endl;return; }
if (list[i-1]->lift)list.push_back(list[i-1]->lift);
if (list[i-1]->right)list.push_back(list[i-1]->right);
}
for (int i = 0;i < list.size();i++) { //输出
if (i)cout << ' ' << list[i]->num;
else cout << list[i]->num;
}
cout << endl;
}
using namespace std;
int main(){
TREE* head=NULL;
string s,svar;
while(getline(cin,s)){ //读取每一行
if (!head) {
head = new TREE; //申请头地址
head->lift = head->right = NULL;
}
stringstream ss(s);
while (ss >> s ) { //读取每一个点
if (s == "()") { //清空并输出。
print(head);
remove(head);
head = NULL;
break;
}
int i = s.find(','); //拆分
svar = s.substr(1, i-1); //数值位
s = s.substr(i + 1, s.size()-1);//路径
if (!insert(head, svar, s)) {
cout << "not complete" << endl;
remove(head);head = NULL;
while (ss >> s)if (s == "()")break;//清空本组数据
while (s != "()")cin >> s;
break; //调出循环,进行下一组
}
}
}
}
Trees on the level UVA - 122的更多相关文章
- Trees on the level UVA - 122 复习二叉树建立过程,bfs,queue,strchr,sscanf的使用。
Trees are fundamental in many branches of computer science (Pun definitely intended). Current state- ...
- 【紫书】Trees on the level UVA - 122 动态建树及bfs
题意:给你一些字符串,代表某个值被插入树中的位置.让你输出层序遍历. 题解:动态建树. 由于输入复杂,将输入封装成read_input.注意输入函数返回的情况 再将申请新节点封装成newnode(). ...
- Trees on the level UVA - 122 (二叉树的层次遍历)
题目链接:https://vjudge.net/problem/UVA-122 题目大意:输入一颗二叉树,你的任务是按从上到下,从左到右的顺序输出各个结点的值.每个结点都按照从根节点到它的移动序列给出 ...
- UVA 122 -- Trees on the level (二叉树 BFS)
Trees on the level UVA - 122 解题思路: 首先要解决读数据问题,根据题意,当输入为“()”时,结束该组数据读入,当没有字符串时,整个输入结束.因此可以专门编写一个rea ...
- UVA.122 Trees on the level(二叉树 BFS)
UVA.122 Trees on the level(二叉树 BFS) 题意分析 给出节点的关系,按照层序遍历一次输出节点的值,若树不完整,则输出not complete 代码总览 #include ...
- Trees on the level(指针法和非指针法构造二叉树)
Trees on the level Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- E - Trees on the level
Trees on the level Background Trees are fundamental in many branches of computer science. Current ...
- hdu 1622 Trees on the level(二叉树的层次遍历)
题目链接:https://vjudge.net/contest/209862#problem/B 题目大意: Trees on the level Time Limit: 2000/1000 MS ( ...
- Trees in a Wood. UVA 10214 欧拉函数或者容斥定理 给定a,b求 |x|<=a, |y|<=b这个范围内的所有整点不包括原点都种一棵树。求出你站在原点向四周看到的树的数量/总的树的数量的值。
/** 题目:Trees in a Wood. UVA 10214 链接:https://vjudge.net/problem/UVA-10214 题意:给定a,b求 |x|<=a, |y|&l ...
随机推荐
- 后端程序员之路 26、CAP理论
可能是CAP理论的最好解释 - 西代零零发 - 博客频道 - CSDN.NEThttp://blog.csdn.net/dc_726/article/details/42784237 CAP理论 - ...
- calcite 概念和架构
1. 前言 Flink使用Calcite构造SQL引擎,那么他们 是怎么合作的? drill, hive,storm 和其他的一干apache 大数据引擎也用calcite , 那么对于同一个sql ...
- css实现0.5像素的底边框。
由于设计图的1px在移动端开发中的像素比是2倍,在实际开发中却是需要1px的线条,虽然最直接的方式是将线条设置为0.5px,但有些移动端对于0.5px的解析为0,变成了无边框的显示.因此处理该需求我们 ...
- 关于深度学习配置的一些tips
建立博客的第一天,将以前记录的一些东西存档下,方便查看. 1安装anaconda 2pycharm破解 配置环境变量3虚拟环境推荐是python3.5或3.6版本 4.安装numpy tensorfl ...
- Windows下的Linux子系统
强调!!!必须是Windows专业版!!! 一.安装运行过程 第一步:打开开发人员模式 第二步:进入 '控制面板 '--'程序'--'启用的Windows功能'--勾选Linux子系统(根据提示进行重 ...
- 第七届蓝桥杯省赛JavaB组——第十题压缩变换
题目: 压缩变换小明最近在研究压缩算法.他知道,压缩的时候如果能够使得数值很小,就能通过熵编码得到较高的压缩比.然而,要使数值很小是一个挑战.最近,小明需要压缩一些正整数的序列,这些序列的特点是,后面 ...
- springboot系列五:springboot整合mybatisplus jsp
一.用IDEA创建项目 1.添加pom.xml <?xml version="1.0" encoding="UTF-8"?> <project ...
- Get和Post区别(转载)
转载自:https://www.cnblogs.com/logsharing/p/8448446.html GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一 ...
- 2017-2018 ACM-ICPC Northern Eurasia(A.Archery Tournament)
题目链接:https://vjudge.net/problem/Gym-101630A 题意: n个事件,t=1 代表增加一个圆心为(x,y),半径为 abs(y)的靶子,t=2,代表射击的坐标为(x ...
- springboot源码解析-管中窥豹系列之bean如何生成?(十四)
一.前言 Springboot源码解析是一件大工程,逐行逐句的去研究代码,会很枯燥,也不容易坚持下去. 我们不追求大而全,而是试着每次去研究一个小知识点,最终聚沙成塔,这就是我们的springboot ...