http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=259#problem/F

Description

呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒语的一个统一规律:如果咒语是以a开头b结尾的一个单词,那么它的作用就恰好是使A物体变成B物体. 
Harry已经将他所会的所有咒语都列成了一个表,他想让你帮忙计算一下他是否能完成老师的作业,将一个B(ball)变成一个M(Mouse),你知道,如果他自己不能完成的话,他就只好向Hermione请教,并且被迫听一大堆好好学习的道理. 
 

Input

测试数据有多组。每组有多行,每行一个单词,仅包括小写字母,是Harry所会的所有咒语.数字0表示一组输入结束. 
 

Output

如果Harry可以完成他的作业,就输出"Yes.",否则就输出"No."(不要忽略了句号) 
 

Sample Input

so
soon
river
goes
them
got
moon
begin
big
0
 

Sample Output

Yes.

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的更多相关文章

  1. HDU1181 变形课(DFS) 2016-07-24 13:31 73人阅读 评论(0) 收藏

    变形课 Problem Description 呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒 ...

  2. hdu1181 变形课(vector容器+dfs)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) Total Submi ...

  3. hdu1181 变形课

    Problem Description 呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒语的一个 ...

  4. 变形课hd1181(DFS)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submis ...

  5. HDU1181 变形课 (回溯法)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submis ...

  6. HDU 变形课 1181【DFS/BFS】

    变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Submissi ...

  7. hdu1181变形课(floyd)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submis ...

  8. HDU-1181 变形课(多种方式,好题)

      首先想到的是并查集,然后WA...原因在这,我第一次敲的是Find(1) == Find(12)来作为可以成功的条件,实际上这样是不行的,比方说 bell 和 mail实际上是不满足条件的,可以理 ...

  9. 变形课(DFS hdu 1181)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submis ...

随机推荐

  1. 【python系列】python初识

    前言 Python是一种高层次,解释,互动性和面向对象的脚本语言,Python被设计成具有很强的可读性语言.它采用应用关键字,而其他语言一般使用标点符号,并且具有比其他语言有较少的语法结构. Pyth ...

  2. css笔记 - 张鑫旭css课程笔记之 relative 篇

    relative地址 relative 对 absolute的限制作用 限制left/top/right/bottom(方位值)定位 限制描述:absolute设置了方位值时,这些方位值是相对于pos ...

  3. Sencha Touch 实战开发培训 电子书 基础篇

    本期课程基于Sencha Touch 2.4.1,属于新手实战入门课程,侧重于实用性. 课程目录: 开源Demo:https://bitbucket.org/moLangZaiShi/demo 本课程 ...

  4. 部署OpenStack问题汇总(一)--使用packstack安装openstack:源问题的处理

    在安装的过程中,遇到了源的问题,找不到包的网页:    重新打开 预装源地址,打开epel-openstack-havana.repo 文件,显示如下: # Place this file in yo ...

  5. INTRO: THE DAWN (亡灵序曲) 中独白

    As the last ship sailed towards the distant horizon I sat there watching on a rock My mind slowly dr ...

  6. Logstash自带正则表达式

    USERNAME [a-zA-Z0-._-]+ USER %{USERNAME} INT (?:[+-]?(?:[-]+)) BASE10NUM (?<![-.+-])(?>[+-]?(? ...

  7. 各浏览器Cookie大小、个数限制【转】

    先插入一条广告,博主新开了一家淘宝店,经营自己纯手工做的发饰,新店开业,只为信誉!需要的亲们可以光顾一下!谢谢大家的支持!店名: 小鱼尼莫手工饰品店经营: 发饰.头花.发夹.耳环等(手工制作)网店: ...

  8. jQuery生成一个DIV容器,ID是"rating".

    我们需要一些服务器端代码,这个例子中用到了一个PHP文件,读取rating参数然后返回rating总数和平均数.看一下rate.php代码.虽然这些例子也可以不使用AJAX来实现,但显示我们不会那么做 ...

  9. 2018C语言第二次作业

    一.学习内容总结 1.指针是一种数据类型,同样占有空间,其存储的是内存地址: 2.定义指针变量要在变量名之前加“*”字符表示: 3.“&”是取地址运算符,“*”是间接运算符: (注:声名和使用 ...

  10. poj1696 Space Ant【计算几何】

    含极角序排序模板.   Space Ant Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5334   Accepted:  ...