HDU - 1622 用到了层次遍历
题意:
给出一些字符串,由(,)包着,表示一个节点,逗号前面是节点的值,后面是节点从根节点走向自己位置的路线,输入以( )结尾,如果这组数据可以构成一个完整的树,输出层次遍历结果,否则输出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 用到了层次遍历的更多相关文章
- hdu 1622 Trees on the level(二叉树的层次遍历)
题目链接:https://vjudge.net/contest/209862#problem/B 题目大意: Trees on the level Time Limit: 2000/1000 MS ( ...
- HDU 1622
http://acm.hdu.edu.cn/showproblem.php?pid=1622 白书上6.3.2二叉树层次遍历的例题,层次遍历用bfs,建立二叉树,很基础的题目 #include < ...
- lintcode二叉树的锯齿形层次遍历 (双端队列)
题目链接: http://www.lintcode.com/zh-cn/problem/binary-tree-zigzag-level-order-traversal/ 二叉树的锯齿形层次遍历 给出 ...
- <二叉树的基本操作(有层次遍历)>
#include<stdio.h> #include<stdlib.h> #include<string.h> #define num 100 #define OK ...
- uva 11234 Expressions 表达式 建树+BFS层次遍历
题目给出一个后缀表达式,让你求从下往上的层次遍历. 思路:结构体建树,然后用数组进行BFS进行层次遍历,最后把数组倒着输出就行了. uva过了,poj老是超时,郁闷. 代码: #include < ...
- 【二叉树遍历模版】前序遍历&&中序遍历&&后序遍历&&层次遍历&&Root->Right->Left遍历
[二叉树遍历模版]前序遍历 1.递归实现 test.cpp: 12345678910111213141516171819202122232425262728293031323334353637 ...
- lintcode: 二叉树的锯齿形层次遍历
题目 二叉树的锯齿形层次遍历 给出一棵二叉树,返回其节点值的锯齿形层次遍历(先从左往右,下一层再从右往左,层与层之间交替进行) 样例 给出一棵二叉树 {3,9,20,#,#,15,7}, 3 / \ ...
- lintcode : 二叉树的层次遍历II
题目 二叉树的层次遍历 II 给出一棵二叉树,返回其节点值从底向上的层次序遍历(按从叶节点所在层到根节点所在的层遍历,然后逐层从左往右遍历) 样例 给出一棵二叉树 {3,9,20,#,#,15,7}, ...
- lintcode : 二叉树的层次遍历
题目 二叉树的层次遍历 给出一棵二叉树,返回其节点值的层次遍历(逐层从左往右访问) 样例 给一棵二叉树 {3,9,20,#,#,15,7} : 3 / \ 9 20 / \ 15 7 返回他的分层遍历 ...
随机推荐
- IP 转发分组的流程
IP 转发分组的流程 数据路由:路由器在不同网段转发数据包: 网络畅通的条件:数据包能去能回: 从源网络发出时,沿途的每一个路由器必须知道到目标网络下一跳给哪个接口: 从目标网络返回时,沿途的每一个路 ...
- git指令-管理修改
git指令-管理修改 git管理的不是文件,而是修改 eg:对readme.txt文件进行修改一行 在最后追加一句git has to tracked 然后添加,并且查看状态 cat +文件名称 表示 ...
- Python基本小程序
目录 Python基本小程序 一.筛选从1-100所有的奇数 二.筛选从0-100所有的偶数 三.求1-100之间所有的偶数和,奇数和 四.三个数由小到大输出 五.四个数字重复数字的三位数 Pytho ...
- UBB代码
UBB代码是HTML(标准通用标记语言下的一个应用)的一个变种,是Ultimate Bulletin Board (国外的一个BBS程序)采用的一种特殊的TAG.您也许已经对它很熟悉了.UBB代码很简 ...
- 对HTML语义化的一些理解和记录
什么是HTML语义化 说HTML语义化就要先说说HTML到底负责的什么?下面摘自维基百科: 超文本标记语言(英语:HyperText Markup Language,简称:HTML)是一种用于创建网页 ...
- Flutter 拖拽控件Draggable看这一篇就够了
注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 Draggable系列组件可以让我们拖动组件. Dragg ...
- mysql 学习日记 悲观和乐观锁
理解 悲观锁就是什么事情都是需要小心翼翼,生怕弄错了出大问题, 一般情况下 "增删改" 都是有事务在进行操作的,但是 "查" 是不需要事务操作的, 但是凡事没 ...
- 第一个爬虫经历----豆瓣电影top250(经典案例)
因为要学习数据分析,需要从网上爬取数据,所以开始学习爬虫,使用python进行爬虫,有好几种模拟发送请求的方法,最基础的是使用urllib.request模块(python自带,无需再下载),第二是r ...
- JVM05——JVM类加载机制知多少
我们已经讲过 JVM 相关的很多常见知识点,感兴趣的朋友可以在我的往期文章中查看.接下来将继续为各位带来 JVM 类加载机制.关注我的公众号「Java面典」了解更多 Java 相关知识点. 类生命周期 ...
- 代号为 Kyria 的 Manjaro Linux 19.0 系统正式发布
Xfce版本仍然是主打,此版本Xfce更新到4.14,并且主要致力于在桌面和窗口管理器上完善用户体验. KDE版本提供了功能强大.成熟且丰富的Plasma 5.17桌面环境,此版本进行了完全重新设计. ...