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. 【MD5加密】MD5加密编码的坑

    MD5 MD5即Message-Digest Algorithm (信息-摘要算法5),用于确保信息传输完整一致. 是计算机广泛使用的杂凑算法之一(又译摘要算法.哈希算法),主流编程语言普遍已有MD5 ...

  2. WP8.1学习系列(第二十五章)——控件样式

      XAML 框架提供许多自定义应用外观的方法.通过样式可以设置控件属性,并重复使用这些设置,以便保持多个控件具有一致的外观. 路线图: 本主题与其他主题有何关联?请参阅: 使用 C# 或 Visua ...

  3. 让A超链接无效的办法 阻止元素发生默认的行为

    $("a").click(function(event){ event.preventDefault(); }); event.preventDefault(); 方法阻止元素发生 ...

  4. [原]openstack-kilo--issue(一) httpd汇总

    /** 系统环境:redhat7.2 repo:163 openstack version : kilo author: lihaibo **/ 问题1:Invalid command 'group= ...

  5. Linux系统启动内幕

    经过对Linux系统有了一定了解和熟悉后,想对其更深层次的东西做进一步探究.这当中就包括系统的启动流程.文件系统的组成结构.基于动态库和静态库的程序在执行时的异同.协议栈的架构和原理.驱动程序的机制等 ...

  6. 2333: [SCOI2011]棘手的操作[离线线段树]

    2333: [SCOI2011]棘手的操作 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2325  Solved: 909[Submit][Stat ...

  7. 【AngularJs-模块篇-Form篇】

    1.模块 <!doctype html> <html lang="en-US" ng-app="myApp"> <head> ...

  8. Ubuntu安装配置MySQL数据库,Apache,PHP

    MySQL安装 第一步:首先检查是否安装: sudo netstat -tap| grep mysql 如果没有任何反应则没有安装 第二步:执行命令安装mysql: sudo apt-get inst ...

  9. 9.20 session

    2018-9-20 13:14:40 Cookie session 参考 :http://www.cnblogs.com/liwenzhou/p/8343243.html 类视图  cbv 注册 ur ...

  10. ASP.NET MVC中ViewBag和ViewData的区别

    在MVC3.0以上我们会用到ViewBag或者ViewData进行页面传值,对比一下二者的差距: ViewData ViewBag 基于key/value的字典集合 dynamic类型对象 从ASP. ...