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. WP8.1学习系列(第八章)——透视Pivot设计指南

    在本文中 描述 应做事项和禁止事项 其他使用指南 相关主题 重要的 API Pivot class (XAML) PivotItem class (XAML) Windows Phone 应用:具有透 ...

  2. windows下使用git管理代码,其中出现的问题的解决办法

    和朋友共同开发一个小项目,所以就涉及到了代码管理这块,刚开始想到的是使用svn,但是外网访问svn的时候需要使用花生壳来弄一个动态的域名,中间出了很多错误,感觉有点麻烦,所以就想到看看还有别的管理代码 ...

  3. LeetCode 20 Valid Parentheses (括号匹配问题)

    题目链接 https://leetcode.com/problems/valid-parentheses/?tab=Description   Problem: 括号匹配问题. 使用栈,先进后出!   ...

  4. pam和sasl

    这几天使用在Postfix搭建一个Webmail的平台,用户认证这一块最终使用了PAM.想整理一下思路,让自己对PAM有个更加清晰的认识. 1.      PAM的简介 PAM全称是:Pluggabl ...

  5. github的README.md文件格式

    一.在线编辑器:stackedit 网址:https://stackedit.io/ README.md是使用Markdown语法.基本规则如下: Markdown 语法速查表 1 标题与文字格式 标 ...

  6. Mongodb之使用rpm包安装配置启动

    下载rpm包 wget https://mirrors.aliyun.com/mongodb/yum/redhat/7Server/mongodb-org/3.2/x86_64/RPMS/mongod ...

  7. HDU 3903 Trigonometric Function(数学定理)

    Trigonometric Function Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 125536/65536 K (Java/Oth ...

  8. SSH免密码登录配置方法详解

    1.测试主机配置信息: 192.168.100.236 db06.chavin.king db06 192.168.100.237 db07.chavin.king db07 2.创建测试用户: gr ...

  9. 使用Homebrew在Mac OS X EI Capitan上安装与配置nginx和PHP

    安装nginx brew install nginx sudo nginx 测试安装 在浏览器打开下面的链接地址 http://localhost:8080 nginx.conf配置 # HTTPS ...

  10. 分析 mongodb admin local 修改ip 热修改

    分析 mongodb   admin  local 更改ip前 [root@e ~]# mongo mongodb://admin:adminpwd123@10.144.114.152 MongoDB ...