题意:

给出一些字符串,由(,)包着,表示一个节点,逗号前面是节点的值,后面是节点从根节点走向自己位置的路线,输入以( )结尾,如果这组数据可以构成一个完整的树,输出层次遍历结果,否则输出not complete,即不是一个完整的树 或者有的点被覆盖了多次。

思路:

按照路径字符串的长短从小到大排序,然后建立二叉树,最后进行层次遍历,看能遍历到多少个点,如果遍历到的点与输入的点的个数相同,则输出层次遍历顺序。

注意:

要多组输入,栽了两次了

有一组数据 (,) () 程序运行答案是0 ,但我认为从题面意思理解是not complete ,这个点没有被赋值,所以不是完整的树,或者说是空树。

看代码:

#include<algorithm>
#include<stdio.h>
#include<queue>
#include<string.h>
using namespace std;
struct qq
{
int val=-1;
char dis[301];
} q[10110];
bool cmp(qq a,qq b)
{
if(strlen(a.dis)!=strlen(b.dis))
return strlen(a.dis)<strlen(b.dis);
}
struct node
{
int val;
node *lch,*rch;
};
node *insert(node *p,char *p1,int x)
{
if(p1[0]=='\0')
{
node *q=new node;
q->val=x;
q->lch=q->rch=NULL;
return q;
}
if(p==NULL)
return p;
if(p1[0]=='R')
{
p->rch=insert(p->rch,p1+1,x);
return p;
}
else if(p1[0]=='L')
{
p->lch=insert(p->lch,p1+1,x);
return p;
}
}
struct QQ
{
int f,val,h;
} Q[10101];
bool cmp1(QQ a,QQ b)
{
if(a.f!=b.f)
return a.f<b.f;
return a.h<b.h;
}
int r=0;
typedef struct node *tree;
int ans[1010],kk;
void find(node *p)//层序遍历函数
{
queue<tree>q;
if(p==NULL)
return;
q.push(p);
node *qq;
while(!q.empty())
{
qq=q.front();
q.pop();
ans[kk++]=qq->val;
if(qq->lch!=NULL) q.push(qq->lch);
if(qq->rch!=NULL) q.push(qq->rch); }
}
int main()
{
char s[301];
while(~scanf("%s",s))
{
memset(ans,0,sizeof(ans));
int w=0;
if(s[0]=='('&&s[1]==')')
continue;
int k=0,i,j;
for(i=1; s[i]!=','; i++)
k=k*10+s[i]-'0';
q[w].val=k;
for(i++,j=0; s[i]=='R'||s[i]=='L'; i++,j++)
q[w].dis[j]=s[i];
q[w].dis[j]='\0';
w++;
while(1)
{
scanf("%s",s);
if(s[0]=='('&&s[1]==')')
break;
k=0;
for(i=1; s[i]!=','; i++)
k=k*10+s[i]-'0';
q[w].val=k;
for(i++,j=0; s[i]=='R'||s[i]=='L'; i++,j++)
q[w].dis[j]=s[i];
q[w].dis[j]='\0';
w++;
}
sort(q,q+w,cmp);
node *p=NULL;
for(int i=0; i<w; i++)
p=insert(p,q[i].dis,q[i].val);
r=0;
kk=0;
find(p);
if(kk==w)
{
for(int i=0; i<kk-1; i++)
printf("%d ",ans[i]);
printf("%d\n",ans[kk-1]);
}
else
printf("not complete\n");
}
return 0;
}

HDU - 1622 用到了层次遍历的更多相关文章

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

    题目链接:https://vjudge.net/contest/209862#problem/B 题目大意: Trees on the level Time Limit: 2000/1000 MS ( ...

  2. HDU 1622

    http://acm.hdu.edu.cn/showproblem.php?pid=1622 白书上6.3.2二叉树层次遍历的例题,层次遍历用bfs,建立二叉树,很基础的题目 #include < ...

  3. lintcode二叉树的锯齿形层次遍历 (双端队列)

    题目链接: http://www.lintcode.com/zh-cn/problem/binary-tree-zigzag-level-order-traversal/ 二叉树的锯齿形层次遍历 给出 ...

  4. <二叉树的基本操作(有层次遍历)>

    #include<stdio.h> #include<stdlib.h> #include<string.h> #define num 100 #define OK ...

  5. uva 11234 Expressions 表达式 建树+BFS层次遍历

    题目给出一个后缀表达式,让你求从下往上的层次遍历. 思路:结构体建树,然后用数组进行BFS进行层次遍历,最后把数组倒着输出就行了. uva过了,poj老是超时,郁闷. 代码: #include < ...

  6. 【二叉树遍历模版】前序遍历&&中序遍历&&后序遍历&&层次遍历&&Root->Right->Left遍历

    [二叉树遍历模版]前序遍历     1.递归实现 test.cpp: 12345678910111213141516171819202122232425262728293031323334353637 ...

  7. lintcode: 二叉树的锯齿形层次遍历

    题目 二叉树的锯齿形层次遍历 给出一棵二叉树,返回其节点值的锯齿形层次遍历(先从左往右,下一层再从右往左,层与层之间交替进行) 样例 给出一棵二叉树 {3,9,20,#,#,15,7}, 3 / \ ...

  8. lintcode : 二叉树的层次遍历II

    题目 二叉树的层次遍历 II 给出一棵二叉树,返回其节点值从底向上的层次序遍历(按从叶节点所在层到根节点所在的层遍历,然后逐层从左往右遍历) 样例 给出一棵二叉树 {3,9,20,#,#,15,7}, ...

  9. lintcode : 二叉树的层次遍历

    题目 二叉树的层次遍历 给出一棵二叉树,返回其节点值的层次遍历(逐层从左往右访问) 样例 给一棵二叉树 {3,9,20,#,#,15,7} : 3 / \ 9 20 / \ 15 7 返回他的分层遍历 ...

随机推荐

  1. python爬虫所遇问题列举

    1.通过python socket库来构造请求报文,向服务器发送图片请求时 (1)图片在浏览器请求头中的remote address信息跟通过python socket输出远程连接地址和端口号不一致 ...

  2. 有点长的博客:Redis不是只有get set那么简单

    我以前还没接触Redis的时候,听到大数据组的小伙伴在讨论Redis,觉得这东西好高端,要是哪天我们组也可以使用下Redis就好了,好长一段时间后,我们项目中终于引入了Redis这个技术,我用了几下, ...

  3. JavaScript(5)--- 面向对象 + 原型

    面向对象 + 原型 面向对象这个概念并不陌生,如 C++.Java 都是面向对象语言.面向对象而言都会现有一个类的概念 ,先有类再有对象.类是实例的类型模板. 比如人类 是一个类 张三 李四 就是一个 ...

  4. 正式学习MVC 05

    1.剃须刀模板razor的使用 1)混编 循环语法 @model List<MVCStudy.Models.Student> @{ ViewBag.Title = "List&q ...

  5. 前端每日实战:111# 视频演示如何用纯 CSS 创作一只艺术的鸭子

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/aaoveW 可交互视频 此视频是可 ...

  6. JZOJ 3927. 【NOIP2014模拟11.6】可见点数

    3927. [NOIP2014模拟11.6]可见点数 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description ZP ...

  7. mui中如何使用tab来切换子页面 mui-bar, mui-bar-tab

    mui是前端框架但是很多人用它写移动端 那么mui底部切换是怎么做到的呢? 如何点击某个tab来切换不同的页面? 解答: 1首先我们需要引入mui框架的底部tab元素 代码如下 <!--tabl ...

  8. python自动化第二课 - python基础

    1.标识符(identitifier),识别身份 定义:在编程语言中,标识符就是用户编程时使用的名字,用于给变量.常量.函数.语句块等命名 标识符命令规范: 1)英文,数字以及下划线(_)但不能以数字 ...

  9. 树莓派3b+ 交叉编译 及升级 kernel

    安装 gcc pkg 等工具sudo apt-get install build-essential git 官方介绍 https://www.raspberrypi.org/documentatio ...

  10. PHP eval变量延迟赋值

    $str = 'and {$prev}name like \'%五子棋%\'';$prev = "table.";eval("\$str = \"$str\&q ...