是否可以把树上结点的编号,然后把二叉树存储在数组中呢?很遗憾如果结点在一条链上,那将是2^256个结点

所以需要采用动态结构

  • 首先要读取结点,建立二叉树addnode()+read_input()承担这样的工作
  • 然后遍历二叉树,读取结点编号输出bfs()

这道题有内存池应用的背景

附链接  http://blog.csdn.net/shawngucas/article/details/6574863

#include <cstdio>
#include <cstring>
#include <vector>
#include <queue>
using namespace std;
const int maxn=256+5;
bool failed;
char s[maxn];
struct Node{
bool have_value;//是否被赋值过
int v;//结点值
Node *left,*right;
Node():have_value(false),left(NULL),right(NULL){}//构造函数
};
Node* root;//二叉树的根节点,指针类型给了,但是指针是空的
//如果要定义一棵二叉树,一般是要定义一个“结点”类型的struct(如叫Node),
//然后保存树根的指针(Node *root) Node * newnode(){
return new Node();
}
//程序动态申请内存,请注意内存泄漏
void remove_tree(Node *u){
//后序遍历 先递归地把当前结点的左子树删除 再递归地把当前结点的右子树删除完,最后考虑当前结点
if(u==NULL) return ;
remove_tree(u->left);
remove_tree(u->right);
delete u;
/*
//前序遍历
delete u;
remove_tree(u->left);
remove_tree(u->right);
//中序遍历
remove_tree(u->left);
delete u;
remove(u->right);
*/
}
//addnode(11,"LL)")
void addnode(int v,char* s){
int n=strlen(s);
Node* u =root;
for(int i=0;i<n;i++)
if(s[i]=='L'){ //左子结点如果空建立新结点
if(u->left==NULL){
u->left=newnode();
}
u=u->left;
}
else if(s[i]=='R'){ //右子结点如果空建立新结点
if(u->right==NULL){
u->right=newnode();
}
u=u->right;
}
if (u->have_value) failed=true; //这里错了,先忍着,主函数再说
u->v=v;
u->have_value=true;
}
bool read_input(){
failed=false;//初始化成功
remove_tree(root);//先回收树
root=newnode();//创建根结点
for(;;){
if(scanf("%s",s)!=1) return false;//!!整个输入结束
if(!strcmp(s,"()")) break;
int v;
sscanf(&s[1],"%d",&v);//(11,LL)对应11,LL)
addnode(v,strchr(s,',')+1);//查找逗号,然后插入结点
}
return true;
}
//包括用vector ans记录树结点编号的工作
bool bfs(vector <int> &ans){
queue<Node*> q;
ans.clear();
q.push(root);//队列中初始只有一个根结点
while(!q.empty()){
Node* u=q.front();q.pop();
if(!u->have_value) return false;
ans.push_back(u->v);//增加结点值到输出序列尾部
if(u->left!=NULL) q.push(u->left);//让左子结点进队(如果有的话)
if(u->right!=NULL) q.push(u->right);//让右子结点进队(如果有的话)
}
return true;
}
int main(){
vector <int> ans;
while(read_input()){
if(!bfs(ans)) failed=true;//最后一层判断输入是否正确
if(failed) printf("not complete\n");
else {
for (int i=0;i<ans.size();i++){
printf(" ");
printf("%d",ans[i]);
}
printf("\n");
}
}
return 0;
}

  

Uva 122 树的层次遍历 Trees on the level lrj白书 p149的更多相关文章

  1. UVa 122 (二叉树的层次遍历) Trees on the level

    题意: 输入一颗二叉树,按照(左右左右, 节点的值)的格式.然后从上到下从左到右依次输出各个节点的值,如果一个节点没有赋值或者多次赋值,则输出“not complete” 一.指针方式实现二叉树 首先 ...

  2. UVa 122 树的层次遍历

    题意: 给定一颗树, 按层次遍历输出. 分析: 用数组模拟二叉树, bfs即可实现层次遍历 #include <bits/stdc++.h> using namespace std; st ...

  3. Trees on the level UVA - 122 (二叉树的层次遍历)

    题目链接:https://vjudge.net/problem/UVA-122 题目大意:输入一颗二叉树,你的任务是按从上到下,从左到右的顺序输出各个结点的值.每个结点都按照从根节点到它的移动序列给出 ...

  4. 树的层次遍历(Trees on the level,UVA 122)

    题目描述: 题目思路: 1.用结构链表来建树 2.用队列来实现层次遍历,当遍历到根节点时,将其子节点压入队列 #include <iostream> #include <cstdli ...

  5. 编程练习:实现树的层次遍历 (CVTE笔试)

    直接层次遍历是比较简单的,但是题目要求的分层打印,这就变得稍微有些麻烦 我是采用两个队列的方法实现. 1.将树结构入队列1. 2.当队列1和队列2都不为空的时候,则一直循环. 3.当队列1不为空的时候 ...

  6. [Swift]LeetCode103. 二叉树的锯齿形层次遍历 | Binary Tree Zigzag Level Order Traversal

    Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...

  7. [Swift]LeetCode107. 二叉树的层次遍历 II | Binary Tree Level Order Traversal II

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...

  8. 二叉树的锯齿形层次遍历 · Binary Tree Zigzag Level Order Traversal

    [抄题]: 给出一棵二叉树,返回其节点值的锯齿形层次遍历(先从左往右,下一层再从右往左,层与层之间交替进行) [思维问题]: 不知道反复切换要怎么做:用boolean normalOrder当作布尔型 ...

  9. 【遍历二叉树】04二叉树的层次遍历【Binary Tree Level Order Traversal】

    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 给定一个二叉树,返回他的层次遍历的 ...

随机推荐

  1. 10亿美元融资腾讯跟头,Grail要用基因测序做癌症早期筛查

    癌症超早期筛查:"在干草堆中寻找缝衣针"癌症是人类的噩梦,尤其是中晚期癌症,但很多时候,当患者感觉到身体不适而去医院检查时,病情都已经到了中晚期,很难治愈.而有研究表明,早期癌症患 ...

  2. 文件存储B+树

    文件存储要选用B+树这样的数据结构 “文件存储要选用B+树这样的数据结构”——没记错的话,这是严蔚敏那本数据结构书上的一句结论.不知道是我没细看还是她没细讲,反正当时纯粹应试地记了这么个结论.不求甚解 ...

  3. WPF 杂谈——Trigger触发器

    笔者在使用的WPF过程中,见过的触发器有三种:Trigger.DataTrigger.EventTrigger.其中最为常用的要属Trigger.至于触发器的作用就是当某个属性的值发生变化,应该去做某 ...

  4. 13.如何生成订单号,用uuid

    String orderNum = UUID.randomUUID().toString().replaceAll("-", "");

  5. 点击率模型AUC

    一 背景       首先举个例子:                          正样本(90)                       负样本(10)         模型1预测      ...

  6. Windows PowerShell 默认颜色

    屏幕背景:1,36,86 屏幕文字:238,237,240 弹出文字:0,128,128 弹出窗口背景:255,255,255

  7. 使用base64提升视觉效果体验

    最近在做一个微信端的小项目,前端代码写完后,就放在手机端测试,没什么问题,但是页面在加载和渲染时的效果却让人有些不爽,虽然是个小项目,我大可不必做这些,但是看着页面的闪动,就忍不住想做些什么. 先说说 ...

  8. Maven下从HDFS文件系统读取文件内容

    需要注意以下几点 1.所以的包都是org.apache.hadoop.XXX 2.三个配置文件要放到指定文件夹中等待文件系统读取(src/main/resources):core-site.xml h ...

  9. Day2_数字类型_字符串类型_列表类型_元组_字典_集合_字符编码_文件处理

    数字类型: 作用:年纪,等级,薪资,身份证号等: 10进制转为2进制,利用bin来执行. 10进制转为8进制,利用oct来执行. 10进制转为16进制,利用hex来执行. #整型age=10 prin ...

  10. chrome浏览器iframe兼容性问题,隐藏起来再显示滚动条消失?

    前言:在调试页面时发现谷歌浏览器bug,版本: 58.0.3029.81 问题描述: 1. 页面中,选项卡里面是IFrame,页面初始显示时有纵向滚动条出现 2. 来回切换选项卡一次,原来选项卡页面的 ...