是否可以把树上结点的编号,然后把二叉树存储在数组中呢?很遗憾如果结点在一条链上,那将是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. JAVA 23种开发模式详解(代码举例)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  2. CSS技巧和经验列表

    如何清除图片下方出现几像素的空白间隙? img{display:block;} 如何让文本垂直对齐文本输入框? input{vertical-align:middle;} 如何使文本溢出边界显示为省略 ...

  3. JavaScript面向对象轻松入门之继承(demo by ES5、ES6)

    继承是面向对象很重要的一个概念,分为接口继承和实现继承,接口继承即为继承某个对象的方法,实现继承即为继承某个对象的属性.JavvaScript通过原型链来实现接口继承.call()或apply()来实 ...

  4. 搭建phabricator代码审核工具

    phabricator 依赖环境 系统centos,mysql,php,nginx 1.下载安装脚本 https://secure.phabricator.com/source/phabricator ...

  5. Sqlserver 2005 跨数据库 导入数据

    --Sqlserver 2005 跨数据库 导入数据:--SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/O ...

  6. java登录时数据库验证账户密码-mysql

    一:连接数据库: package login; import java.sql.*; public class conmysql { String drivername="com.mysql ...

  7. 自己开源的leaf-snowflake

    拜读了美团点评技术团队博客的"Leaf--美团点评分布式ID生成系统(http://tech.meituan.com/MT_Leaf.html)"之后,收获很多.纸上得来终觉浅 绝 ...

  8. Mac之OS系统下搭建JavaEE环境 <二> 之Tomcat 的安装配置

    二.Tomcat的安装与配置 1.下载Tomcat 找到Tomcat的官网 百度搜索Tomcat 点击下载即可 下载网址:http://tomcat.apache.org/download-80.cg ...

  9. SSH中的Invalid action class configuration that references an unknown class named.......

    最近用SSH框架做项目的时候页面提交数据到后台,遇到了这个问题,百度了一下,网上的解决办法无非两种: 1.检查struts.xml  ,applicationContext.xml的配置是否正确 2. ...

  10. jsonp的原理和实现

    什么是JSONP? javascript高级程序设计中是这样介绍jsonp的: jsonp是JSON with padding(填充式JSON或参数式JSON )的简写,是应用JSON的一种新方法,在 ...