hdu1181 (变形课)简单地dfs
http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=259#problem/F
Description
Harry已经将他所会的所有咒语都列成了一个表,他想让你帮忙计算一下他是否能完成老师的作业,将一个B(ball)变成一个M(Mouse),你知道,如果他自己不能完成的话,他就只好向Hermione请教,并且被迫听一大堆好好学习的道理.
Input
Output
Sample Input
Sample Output
Hint
Hint Harry 可以念这个咒语:"big-got-them".
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
using namespace std;
struct node
{
char a[];//存储单词
int v;//相当于标记数组
}q[];
int num[];//用于记录出现的b开头的单词
int tt,flag;
void dfs(int x)
{
if(flag)
return ;
else if(q[x].a[strlen(q[x].a)-]=='m')
{
flag=;
return ;
}
for(int i=;i<tt;i++)
{
if(!q[i].v&&q[i].a[]==q[x].a[strlen(q[x].a)-])//单词的末尾字母等于新单词的开头的字母
{
q[i].v=;
dfs(i);
}
}
}
int main()
{
int ll=;
while(scanf("%s",q[].a)!=EOF)
{
tt=;
ll=;
q[].v=;
memset(num,,sizeof(num));
flag=;
if(q[].a[]=='b')
{
num[ll++]=;//记录b开头单词存储的位置
}
while(scanf("%s",q[tt].a)!=EOF)
{
if(q[tt].a[]=='b')
{
num[ll++]=tt;
}
q[tt].v=;
if(q[tt].a[]=='') break;
tt++;
}
for(int i=;i<ll;i++)
{
if(q[num[i]].v==)//没有访问过 数据可能出现b-b
{
q[i].v=;
dfs(num[i]);
}
else if(flag) break;
}
if(flag==) printf("Yes.\n");
else printf("No.\n");
}
return ;
}
tjj的代码,把单词的首字母与尾字母存在地图中。言简意赅。写得好。
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<iostream>
#include<queue> using namespace std; #define N 1086
int map[N][N],v[N]; void BFS()
{
memset(v,,sizeof(v));
queue<int>q;
q.push();
v[] = ;
while(!q.empty())
{
int t = q.front();
q.pop();
if(t == )
{
printf("Yes.\n");
return ;
}
int i;
for(i=; i<=; i++)
{
if(map[t][i] == && v[i] == )
{
q.push(i);
v[i] = ;
}
}
}
printf("No.\n");
} int main()
{
char a[];
while(scanf("%s",a)!=EOF)
{
if(a[] == '')
{
continue;
}
memset(map,,sizeof(map));
while(a[]!='')
{
int x,y;
int l = strlen(a);
x = a[] - 'a'+;
y = a[l-] - 'a'+;
map[x][y] = ;
scanf("%s",a); }
BFS();
} return ;
}
hdu1181 (变形课)简单地dfs的更多相关文章
- HDU1181 变形课(DFS) 2016-07-24 13:31 73人阅读 评论(0) 收藏
变形课 Problem Description 呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒 ...
- hdu1181 变形课(vector容器+dfs)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Submi ...
- hdu1181 变形课
Problem Description 呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒语的一个 ...
- 变形课hd1181(DFS)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submis ...
- HDU1181 变形课 (回溯法)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submis ...
- HDU 变形课 1181【DFS/BFS】
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Submissi ...
- hdu1181变形课(floyd)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submis ...
- HDU-1181 变形课(多种方式,好题)
首先想到的是并查集,然后WA...原因在这,我第一次敲的是Find(1) == Find(12)来作为可以成功的条件,实际上这样是不行的,比方说 bell 和 mail实际上是不满足条件的,可以理 ...
- 变形课(DFS hdu 1181)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submis ...
随机推荐
- JUnit —— TestSuite 的使用
首先说一下,suite ,中文是 一套,一组 的意思. 那么,TestSuite,顾名思义,就是用来运行一组测试的. 如何使用呢 ? 假设有个这样的测试类 StudentDAOTest ,代码如下: ...
- Hibernate 查询sql结果行数的几种方法
一.前言 这个东西,难度几乎没有,就是繁琐. 一条简单的select count(*) from table_name 都能有多种书写方式. 总是忘,这里记录下. 一 .通过Criteria 查询 C ...
- 替换linux系统文件etc下passwd文件的字段获取真正的root权限
sudo与root 很多人都知道使用linux可以利用sudo来执行一些root权限执行的事情,但是sudo和root还是有很大的区别的. 区别一:sudo可以执行的命令是root账户利用/etc/s ...
- vue-loader的简单例子
一.模块加载器 1.broserify 模块加载器, 只能加载js 2.webpack 模块加载器, 一切东西都是模块, 最后打包到一块 .vue文件 ==> 需要用webpack编译成浏览器 ...
- docker参数expose使用
expose # 暴露端口,但不映射到宿主机,只被连接的服务访问.仅可以指定内部端口为参数 expose: - " - "
- Excel 2007表格内输入http取消自动加上超链接的功能
经常使用Excel表格工作的也许会发现,当我们在表格内输入http://XXXX时,默认情况下都会自动加上超链接,如下: 当我们点击域名准备编辑修改时,往往都会调用浏览器转到该域名之下,达不到编辑修改 ...
- 使用curl进行s3服务操作
最近使用curl对s3进行接口测试,本想写个总结文档,但没想到已有前辈写了,就直接搬过来做个记录吧,原文见: http://blog.csdn.net/ganggexiongqi/article/de ...
- 【转】RTMP/RTP/RTSP/RTCP协议对比与区别介绍
用一句简单的话总结:RTSP发起/终结流媒体.RTP传输流媒体数据 .RTCP对RTP进行控制,同步. 之所以以前对这几个有点分不清,是因为CTC标准里没有对RTCP进行要求,因此在标准RTSP的代码 ...
- VSCode集成TypeScript编译
先安装github客户端和nodeJS客户端吧,直接去官网下载,nodeJS客户端安装完就集成了npm; 查看是否成功: git version node -v npm-v 安装TypeScript ...
- hdu2586(LCA最近公共祖先)
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...