Problem Description
经过锦囊相助,海东集团最终度过了危机,从此。HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强。

这时候,XHD夫妇也退居了二线。并在风景秀美的诸暨市浬浦镇陶姚村买了个房子,開始安度晚年了。

这样住了一段时间。徐总对当地的交通还是不太了解。

有时非常郁闷,想去一个地方又不知道应该乘什么公交车,在什么地方转车,在什么地方下车(事实上徐总自己有车,却一定要与民同乐。这就是徐总的性格)。

徐总常常会问蹩脚的英文问路:“Can you help me?

”。

看着他那迷茫而又无助的眼神,热心的你能帮帮他吗?

请帮助他用最短的时间到达目的地(如果每一路公交车都仅仅在起点站和终点站停,并且随时都会开)。

 
Input
输入数据有多组,每组的第一行是公交车的总数N(0<=N<=10000);

第二行有徐总的所在地start。他的目的地end;

接着有n行。每行有站名s,站名e,以及从s到e的时间整数t(0<t<100)(每一个地名是一个长度不超过30的字符串)。

note:一组数据中地名数不会超过150个。

假设N==-1,表示输入结束。
 
Output
假设徐总能到达目的地,输出最短的时间;否则,输出“-1”。

 
Sample Input
6
xiasha westlake
xiasha station 60
xiasha ShoppingCenterofHangZhou 30
station westlake 20
ShoppingCenterofHangZhou supermarket 10
xiasha supermarket 50
supermarket westlake 10
-1
 
Sample Output
50 Hint:
The best route is:
xiasha->ShoppingCenterofHangZhou->supermarket->westlake 尽管偶尔会迷路。可是由于有了你的帮助
**和**从此还是过上了幸福的生活。 ――全剧终――
 

#include<stdio.h>
#include<string.h>
#include<string>
#include<map>
#define INF 0x3f3f3f3f
#define N 110
using namespace std;
int Map[N][N];
int dis[10100];
bool used[10100];
int n;
int i,j;
void dijkstra(int u)
{
memset(used,0,sizeof(used));
memset(dis,INF,sizeof(dis));
int pos=u;
for(i=1;i<=100;++i)//第一次给dis赋值
{
dis[i]=Map[u][i];
}
dis[u]=0;
used[u]=1;
for(i=1;i<100;++i)//最多执行一百次,由于最多有一百个公交车站
{
int min=INF;
for(j=1;j<=100;++j)
{
if(!used[j]&&dis[j]<min)
{
min=dis[j];
pos=j;
}
}
used[pos]=1;
dis[pos]=min;
for(j=1;j<=100;++j)//把dis数组更新,也叫松弛
{
if(!used[j]&&dis[j]>Map[pos][j]+dis[pos])
{
dis[j]=Map[pos][j]+dis[pos];
}
}
} }
int main()
{
int m;
int u,v,w;
char s1[50],s2[50];
while(scanf("%d",&n),n!=-1)
{
for(i=1;i<=100;++i)
for(j=1;j<=i;++j)
Map[i][j]=Map[j][i]=INF;
map<string,int>mp; scanf("%s%s",s1,s2);
bool flag=0;
if(strcmp(s1,s2)==0) flag=1;
mp[s1]=1;
mp[s2]=2;
int num=3;
while(n--)
{
scanf("%s%s%d",s1,s2,&w);
if(!mp[s1]) mp[s1]=num++;//假设没用过
if(!mp[s2]) mp[s2]=num++; Map[mp[s1]][mp[s2]]=Map[mp[s2]][mp[s1]]=w;
}
if(flag) printf("0\n");
else
{
dijkstra(1);
if(dis[2]==INF) printf("-1\n");
else
printf("%d\n",dis[2]);
}
}
return 0;
}

//SPFA

#include <cstdio>
#include <cstring>
#include <string>
#include <iostream>
#include <map>
#include<queue>
#define M 300
#define INF 0x3f3f3f3f
using namespace std;
int Map[M][M];
int s=0, e=1;
int low[10010];
bool vis[10010];
void SPFA()
{
int i, j;
queue<int> Q;
memset(low, INF, sizeof(low));
memset(vis, 0, sizeof(vis));
vis[1] = 1;
low[1] = 0;
Q.push(1);
while(!Q.empty())
{
int u = Q.front();
Q.pop();
vis[u] = 0;//出队列了。不在队列就变成0
for(i = 1; i <= 100; ++i)
{ if(low[i] > low[u] + Map[u][i])
{
low[i] = low[u] + Map[u][i];
if(!vis[i])
{
vis[i]=1;
Q.push(i);
}
}
}
}
if(low[2] == INF) printf("-1\n");
else printf("%d\n",low[2]);
}
int main()
{
int N;
char s1[40], s2[40];
int u, v, w;
while(scanf("%d",&N) && N != -1)
{
map<string,int>mp;
int flag=0;
for(int i=1;i<=100;++i)
for(int j=1;j<=i;++j)
Map[i][j]=Map[j][i]=INF;
scanf("%s%s",s1,s2);
if(strcmp(s1,s2)==0) flag=1;
mp[s1]=1;
mp[s2]=2;
int num=3;
while(N--)
{
scanf("%s%s%d",s1,s2,&w);
if(!mp[s1]) mp[s1]=num++;
if(!mp[s2]) mp[s2]=num++;
Map[mp[s1]][mp[s2]]=Map[mp[s2]][mp[s1]]=w;
}
if(flag)
{
printf("0\n");
continue;
}
SPFA();
}
return 0;
} /*
6
xiasha xiasha
xiasha station 60
xiasha ShoppingCenterofHangZhou 30
station westlake 20
ShoppingCenterofHangZhou supermarket 10
xiasha supermarket 50
supermarket westlake 10 0
*/

HDU Today HDU杭电2112【Dijkstra || SPFA】的更多相关文章

  1. hdu 1290_献给杭电五十周年校庆的礼物

    Description 或许你曾经牢骚满腹或许你依然心怀忧伤或许你近在咫尺或许你我天各一方 对于每一个学子母校 永远航行在生命的海洋 今年是我们杭电建校五十周年,这是一个值得祝福的日子.我们该送给母校 ...

  2. HDU 1290 献给杭电五十周年校庆的礼物(面分割空间 求得到的最大空间数目)

    传送门: 献给杭电五十周年校庆的礼物 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  3. HDU 4940(杭电更多的学校#7 1006) Destroy Transportation system(到处乱混)

    职务地址:pid=4940">HDU 4940 当时这个题一看就看出来了是网络流的最小割.然后就一直在想建图. .然后突然发现,应该要让T集合的数目最少,不然仅仅要有两个,那这两个的每 ...

  4. HDU 4920(杭电多校训练#5 1010 题) Matrix multiplication(不知道该挂个什么帽子。。。)

    题目地址:pid=4920">HDU 4920 对这个题简直无语到极点. . .竟然O(n^3)的复杂度能过....方法有三.. 1:进行输入优化和输出优化. . (前提是你的输入优化 ...

  5. Age of Moyu HDU - 6386 (杭电多校7A)

    给出n和点,m条边,每条边有各自的标号,进入第一个标号需要消耗1的费用,此后转换标号需要1费用,在同一个标号上走不需要费用.问你从1到n最少需要多少费用. 最短路变形,把第一个点看成不存在的标号,然后 ...

  6. 【HDU】4908 (杭电 BC #3 1002题)BestCoder Sequence ——哈希

    BestCoder Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  7. HDU 1290 献给杭电五十周年校庆的礼物

    题解:http://www.cnblogs.com/forever97/p/3522238.html #include <cstdio> int main() { int n; while ...

  8. GuGuFishtion HDU - 6390 (杭电多校7E)

    啊啊啊啊...全在纸上 字丑...算了算了 然后除法部分都用逆元就好了 还有逆元打表....学到了...牛逼 #include<map> #include<set> #incl ...

  9. Balanced Sequence HDU - 6299(杭电多校1 B)

    题目说要n个字符串串内随意组合以后将这些串放在一起,然后求最长的括号匹配的长度,并不要求是连续的 因为不需要是连续的,所以可以先把已经匹配好的括号加入到答案里面去,先把这些删掉,以为并不影响结果,然后 ...

随机推荐

  1. HTTP的缺点与HTTPS

    a.通信使用明文不加密,内容可能被窃听 b.不验证通信方身份,可能遭到伪装 c.无法验证报文完整性,可能被篡改 HTTPS就是HTTP加上加密处理(一般是SSL安全通信线路)+认证+完整性保护

  2. 【计算机网络】2.5 DNS:因特网的目录服务

    第二章第五节 因特网的目录服务 DNS(域名系统)提供了一种能运行主机名到IP地址转换的因特网目录服务:一方面,他让人能够记住如taobao.com这样的主机别名:另一方面,他提供给路由器可理解的IP ...

  3. rsync 同步多台服务器项目目录

    server1:192.168.10.1server2:192.168.10.2实现server2实时同步server1的数据! ###############server1############# ...

  4. Redux的中间件Middleware不难,我信了^_^

    Redux的action和reducer已经足够复杂了,现在还需要理解Redux的中间件.为什么Redux的存在有何意义?为什么Redux的中间件有这么多层的函数返回?Redux的中间件究竟是如何工作 ...

  5. VIM基础操作方法汇总

    学习自小甲鱼的视频,快速入门vim 目录: 1.光标移动 2.进入插入模式 3.进入普通模式 4.进入命令行模式 5.退出 6.光标跳跃 7.快速跳转行号 8.删除 9.利用数字重复操作 10.撤回 ...

  6. HDU1401 Solitaire

    题目描述:8×8的棋盘上有4个棋子,棋子的运动方法如下:1.如果其上/下/左/右一格没有棋子,则可以去;2.如果其上/下/左/右一格有棋子,而且沿原方向再跳一步没有,则可以去. 给出初始结束位置,问8 ...

  7. 零基础入门学习Python(4)--改进我们的小游戏

    前言 在以前的博客中有做个一个小游戏,但是太简单了,所以这次就来对我们做的小游戏进行改进,改善从以下四个方面进行: 程序猜错的时候要给出提示,例如告诉用户输入的值是大了还是小了. 以前程序每运行一次只 ...

  8. 运维笔记:zabbix的运用(1)安装过程

    前言 如果是用了阿里云或者腾讯云,他们都有各种监控帮我们做好.但是如果是遇到了自己维护自己机房的服务器,那么一些可视化或者监控就很有意义了.监控可能有很多种方案,这里就以比较老牌通吃的zabbix来解 ...

  9. pip 打包项目配置库

    打包项目中配置库(filename为文件名,可修改) pip freeze > filename.txt 安装配置文件中所有的库包 pip install -r filename.txt 如提示 ...

  10. UVa 11998 破碎的键盘(数组实现链表)

    题意: 输入一行字符,其中包含'[' 和 ‘]’, 意思为键盘上的home 和 end 键, 然后模拟字符在键盘上输入. 输入一行最终的结果 分析: 用数组模拟一个链表, 在链表的头尾插入字母然后输出 ...