题意:

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

    今天和大家分享关于 nginx 的一些参数使用 首先,你应该安装了nginx CentOS 安装 nginx 这是很早之前的一篇博客,可以参考. 之前,我们如何去操作 nginx ##简单粗暴法 pk ...

  2. Swift和Objective-C中的协议(protocol)有什么异同

    Swift和Objective-C中的protocol的相同点在于:两者可以被用作代理.Objective-C中的protocol类似于Java中的Interface,在实际开发中主要用与适配器模式( ...

  3. CSS(0)CSS的引入方式

    CSS (cascading  style  sheet)  层叠样式表 css引入的三种方式: 1.行间样式 <!--在body内写入--> <div></div> ...

  4. 2020年,MyBatis常见面试题总结

    Mybatis 技术内幕系列博客,从原理和源码角度,介绍了其内部实现细节,无论是写的好与不好,我确实是用心写了,由于并不是介绍如何使用 Mybatis 的文章,所以,一些参数使用细节略掉了,我们的目标 ...

  5. 关于毕业五年PHP成长疑惑

    1.PHP语法基础是否都会,比如异常捕捉,面向对象,数组操作语法,字符串操作,cookie,session,全局变量,超全局数组,防止sql注入,mysql预处理 2.MYSQL基础语法,字段设计,原 ...

  6. Yuchuan_Linux_C编程之五gdb调试

    一.整体大纲 二.gdb调试 1. 启动gdb start -- 只执行一步    n -- next    s -- step(单步) -- 可以进入到函数体内部    c - continue - ...

  7. A. New Building for SIS Codeforce

    You are looking at the floor plan of the Summer Informatics School's new building. You were tasked w ...

  8. OpenWrt tcpdump 抓包

    路由器用的是 网件的 4300 刷的是石像鬼双固件 1, 安装支持库opkg updateopkg install libpcapopkg install tcpdump 2, 设置条件开始捕获tcp ...

  9. C语言程序设计(十) 字符串

    第十章 字符串 字符串常量是由一对双引号括起来的一个字符串序列 字符串实际就是由若干个有效数字构成且以字符'\0'作为结束的一个字符序列 C语言没有提供字符串数据类型,因此字符串的存取要用字符型数组来 ...

  10. Redis详解(一)

    redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多 包括string(字符串).list(链表).set(集合).zset(sor ...