题意:

给出一些字符串,由(,)包着,表示一个节点,逗号前面是节点的值,后面是节点从根节点走向自己位置的路线,输入以( )结尾,如果这组数据可以构成一个完整的树,输出层次遍历结果,否则输出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. 记一个 Base64 有关的 Bug

    本文原计划写两部分内容,第一是记录最近遇到的与 Base64 有关的 Bug,第二是 Base64 编码的原理详解.结果写了一半发现,诶?不复杂的一个事儿怎么也要讲这么长?不利于阅读和理解啊(其实是今 ...

  2. 一文了解各大图数据库查询语言(Gremlin vs Cypher vs nGQL)| 操作入门篇

    文章的开头我们先来看下什么是图数据库,根据维基百科的定义:图数据库是使用图结构进行语义查询的数据库,它使用节点.边和属性来表示和存储数据. 虽然和关系型数据库存储的结构不同(关系型数据库为表结构,图数 ...

  3. 震惊,当我运行了这条Linux命令后,服务器竟然... (Linux中的删除命令)

    震惊,当我运行了这条Linux命令后,服务器竟然... 0X00 写在前面 大家都听说过删库命令rm -rf /*,但是谁又真正实践过呢?但作为一个程序员,不看看这条命令执行后会发生什么,怎么能甘心呢 ...

  4. jdbc对 数据库的数据进行增删改(两个类)

    1.方法类 package com.com; import java.sql.Connection;import java.sql.DriverManager;import java.sql.Resu ...

  5. 优雅的创建一个JavaScript库

    这篇文章的目的是通过演示一个简单的例子来介绍在JS中实例化和定义一个库的正确方法,以优化他人编写或维护自己的JS库. 在我们深入之前,我做了两点假设: 你知道简单的JavaScript或C语言. 你不 ...

  6. 那些年,我的前端/Java后端书单

    全文为这些年,我曾阅读.深入理解过(或正在阅读学习.即将阅读)的一些优秀经典前端/Java后端书籍.全文为纯原创,且将持续更新,未经许可,不得进行转载.当然,如果您喜欢这篇文章,可以动手点点赞或者收藏 ...

  7. frp 内网穿透访问内网Web服务

    ps:最近想要通过域名(公网)访问或者测试在本地搭建的 web 服务(不想在公网IP服务器上再部署个服务,也不想通过teamview等工具远程卡到爆!), 由于本地机器没有公网 IP,无法将域名解析到 ...

  8. Element-UI饿了么时间组件控件按月份周日期,开始时间结束时间范围限制参数

    在日常开发中,我们会遇到一些情况,在使用Element-UI 限制用户的日期时间范围的选择控制(例如:查询消息开始和结束时间,需要限制不能选择今天之后的时间). 看了网上的一些文档,零零散散.各式各样 ...

  9. nes 红白机模拟器 第1篇

    对比了很多种,开源的 NES 模拟器 VirtuaNES , nestopia , FakeNES , FCEUX , InfoNES , LiteNES 最后决定使用 LiteNES 进行移值,它是 ...

  10. ubuntu16.04 + caffe + SSD 硬件配置

    搞了几个月,终于把SSD试通了,不是科班出身的就是弯路多啊.几个月才跑通了caffe + ssd,痛苦至极,好在柳暗花明.好了,废话不多说,入正题. SSD作为object detection的论文, ...