#include<stdio.h>

#include<string.h>  

#include <iostream>

#include <algorithm>

#include<string>//必须加这个

#include<cstdio>

#define N 11000

#define NN 1100

#define inf 999999999

#include<map>

#include<queue>

using namespace std;

map<string,int>ymap;//对于用这个

struct node {

int x,next;

}f[N*2];

int dis[NN],len,n,head[NN];

void Add(int a,int b) {

f[len].x=b;f[len].next=head[a];

head[a]=len++;

}

int spfa(int u) {

int visit[NN];

memset(visit,0,sizeof(visit));

int cur,i,max;

for(i=0;i<n;i++)

dis[i]=inf;

queue<int>q;

q.push(u);

dis[u]=0;

visit[u]=1;

while(!q.empty()) {

cur=q.front();

q.pop();

for(i=head[cur];i!=-1;i=f[i].next) {

u=f[i].x;

if(!visit[u]) {

q.push(u);

visit[u]=1;

dis[u]=dis[cur]+1;

}

}

}

max=-1;

for(i=0;i<n;i++)

        if(dis[i]>max) 

        max=dis[i];

return max;

}

int main() {

int m,i,f1,f2,ans,cnt;

char s[20],s1[20];

while(scanf("%d",&n),n) {

ymap.clear();

for(i=0;i<n;i++) {

scanf("%s",s);

ymap[s]=i;



}

len=0;

scanf("%d",&m);

memset(head,-1,sizeof(head));

while(m--) {

scanf("%s%s",s,s1);

f1=ymap[s];

f2=ymap[s1];

Add(f1,f2);Add(f2,f1);

}

cnt=-1;

for(i=0;i<n;i++) {

ans=spfa(i);

cnt=cnt>ans?cnt:ans;

}

if(cnt>=inf)

printf("-1\n");

else

printf("%d\n",cnt);

}

return 0;

}

hdu 4460spfa用map来实现的更多相关文章

  1. hdu 1800 (map)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=1800 Flying to the Mars Time Limit: 5000/1000 MS (Java/ ...

  2. [HDU 4585] Shaolin (map应用)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4585 题目大意:不停的插入数字,问你跟他相距近的ID号.如果有两个距离相近的话选择小的那个. 用map ...

  3. hdu 统计难题(map)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1251 map的强大之处,但是运行时间太长. 代码: #include <stdio.h> ...

  4. ACM学习历程—HDU 2112 HDU Today(map && spfa && 优先队列)

    Description 经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强.这时候,XHD夫妇也退居了二线 ...

  5. HDU 2112 HDU Today Dij+map转化

    HDU Today 经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强.这时候,XHD夫妇也退居了二线,并 ...

  6. hdu 4585 map **

    题意: Shaolin temple is very famous for its Kongfu monks.A lot of young men go to Shaolin temple every ...

  7. HDU 4585 Shaolin(map应用+二分)

    题目大意:原题链接 初始少林最开始只有一个老和尚,很多人想进少林,每个人有一个武力值,若某个人想进少林,必须先与比他早进去的并且武力值最接近他的和尚比武, 如果接近程度相同则选择武力值比他小的,按照进 ...

  8. K-D树问题 HDU 4347

    K-D树可以看看这个博客写的真心不错!这里存个版 http://blog.csdn.net/zhjchengfeng5/article/details/7855241 HDU 4349 #includ ...

  9. 第一周训练 | STL和基本数据结构

    A - 圆桌问题: HDU - 4841 #include<iostream> #include<vector> #include<stdio.h> #includ ...

随机推荐

  1. page.php 引入js文件

    2种写法 <script type='text/javascript' src='<?php echo get_template_directory_uri().'/js/jquery-1 ...

  2. PHP的扩展知识

    1. 图片的上传大小受哪一些限制? 答:浏览器 其实php.ini文件里面 1. upload_max_filesize = 2M  限制单个文件上传大小 2. post_max_size = 8M ...

  3. ios学习笔记 UITableView(纯代码) (一)

    参考 “https://www.cnblogs.com/ai-developers/p/4557487.html” UITableViewCell 有一个代码重用 减少资源的浪费 参考  https: ...

  4. 获得select被选中option的value和text

    一:JavaScript原生的方法 1:得到select对象: var myselect=document.getElementById(“test”); 2:得到选中项的索引:var index=m ...

  5. html制作简单框架网页二 实现自己的影音驿站 操作步骤及源文件下载 (可播放mp4、avi、mpg、asx、swf各种文件的视频播放代码)

    新增视频播放功能如下图: 左侧网页left.html代码如下: <meta charset="utf-8"> <body style="backgrou ...

  6. flutter基础

    1.flutter安装 1.参考官网安装sdk https://flutter.io/get-started/install 安卓和IOS需要分别配置对应的开发环境,安卓建议使用as开发,安装Flut ...

  7. mysql 查询数据库参数命令

    1.select @@tx_isolation;    查询数据库设置的事务隔离级别 2.desc table_name;  显示表设计 3.show create table table_name; ...

  8. mac自带终端安装完ohmyZsh后显示乱码

    修改描述文件-添加 选择新导入的 Meslo LG M Regular for Powerline

  9. BST AVL RBT B- B+ 的一些理解

    BST(二叉查找树,排序二叉树),如果数据有序的话,组成的二叉树会形成单列的形式,导致查询效率低AVL(平衡二叉树) 使树的左右高度差的绝对值不超过2,保证了查询效率.但是插入和删除会带来多次旋转,导 ...

  10. SqlServer 2008 创建测试数据

    包含要点: 数据库的循环 . insert select 句式   . 随机数(rand()函数).绝对值(abs()函数) ) ) DECLARE @randomvalue float SET @s ...