HDU Today

Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 21353    Accepted Submission(s): 5094

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
50Hint: The best route is: xiasha->ShoppingCenterofHangZhou->supermarket->westlake虽然偶尔会迷路,但是因为有了你的帮助 **和**从此还是过上了幸福的生活。――全剧终――
 
Author
lgx
#include <stdio.h>
#include <string.h>
#define INF 0x3f3f3f3f
#define MAX_N 160
int g[MAX_N][MAX_N];
int dist[MAX_N];
int used[MAX_N];
//char pre[MAX_N];
char map[MAX_N][40],start[40],end[40];
int sum,N;
void add_edge(int x,int y,int weight)
{if(g[x][y]>weight){g[x][y] = g[y][x] = weight;}
}
void init()
{memset(used,0,sizeof(used));memset(dist,INF,sizeof(dist));
//  memset(pre,-1,sizeof(pre));
}
int search(char name[40])
{ int i;for(i=0;i<sum;i++){if(!strcmp(map[i],name)){return i;}}strcpy(map[sum],name);return sum++;
}
void Dijkstra()
{init();dist[0] = 0;while(1){int u =-1,v,i,min = INF;for(i=0;i<sum;i++){if(min>dist[i] && !used[i]){min = dist[i];u = i;}}used[u] = 1;if(u==-1){break;}for(v=0;v<sum;v++){if(g[u][v]!=INF && dist[v]>dist[u]+g[u][v]){dist[v] = dist[u] + g[u][v];//      pre[v] = u;}}}}
int main()
{char a[40],b[40];int i,weight;while(scanf("%d",&N) && N!=-1){sum = 0;memset(g,INF,sizeof(g));memset(map,0,sizeof(map));scanf("%s%s",start,end);int _s=search(start);int _e=search(end);for(i=1;i<=N;i++){scanf("%s%s%d",a,b,&weight);int x= search(a), y= search(b);add_edge(x,y,weight);}Dijkstra(); if(dist[_e]==INF){printf("-1\n");} else{printf("%d\n",dist[_e]);
/*          int u,v;     输出路径 printf("%s->",map[_s]);v=_e;char s_s[MAX_N][40];memset(s_s,0,sizeof(s_s));int o = 0;while(pre[v]!=-1){strcpy(s_s[o++],map[v]);v=pre[v];}for(i=o-1;i>=1;i--){printf("%s->",s_s[i]);}printf("%s\n",map[_e]);
*/}}return 0;
}

hdu HDU Today2112相关推荐

  1. HDU hdu 2094 产生冠军 拓扑排序 判定环

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2094 对于是否有环,是通过一个N(节点数)的循环来判定.检查并更新每个节点的入度数. 每找到一个入度唯 ...

  2. Python爬虫之HDU提交数据

    前一篇http://www.cnblogs.com/liyinggang/p/6094338.html 使用了爬虫爬取hdu 的代码,今天实现了将数据向hdu 提交的功能,接下来就是需要将两个功能合并 ...

  3. HDU - 2500 做一个正气的杭电人

    OJ地址:https://vjudge.net/problem/HDU-2500 做人要有一身正气,杭电学子都应该如此.比如我们今天的考试就应该做到"诚信"为上. 每次考试的第一个 ...

  4. 做一个正气的杭电人 HDU

    Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submission(s) ...

  5. HDOJ(HDU) 2500 做一个正气的杭电人(水~)

    Problem Description 做人要有一身正气,杭电学子都应该如此.比如我们今天的考试就应该做到"诚信"为上. 每次考试的第一个题目总是很简单,今天也不例外,本题是要求输 ...

  6. 杭电OJ分类题目(1)

    原题出处:HDOJ Problem Index by Type,http://acm.hdu.edu.cn/typeclass.php 杭电OJ分类题目(1) HDU Introduction HDU ...

  7. HDU2500 做一个正气的杭电人【水题】

    做一个正气的杭电人 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  8. 2019.8.1 每周反思

    第一次写这个每周反思呢...woc语文不好就是瞎jb写,但是个人认为还挺有意义的. 这周仿佛肝不太好,感觉刷题刷不动,题解也写不动,不知道为什么.是我不注意休息么?是我学习过度了么?我才13岁啊!(惊 ...

  9. 杭电ACM基础题(2201、2212、2304、2309、2317、2401、2500、2502、2503、1708、1161)

    文章目录 2201.熊猫阿波的故事[概率问题] 2212.DFS[各位数的阶乘之和等于该数] 2304.Electrical Outlets[电源板接口] 2309.ICPC Score Totali ...

最新文章

  1. c++ lambda函数_C++ Lambda表达式
  2. 【计算机网络】传输层 : TCP 拥塞控制 ( 慢开始 | 拥塞避免 | 快重传 | 快恢复 )
  3. unity menuitem_Unity热更_打AssetBundles包
  4. grunt -- javascript自动化工具
  5. HDU4372 Count the Buildings
  6. flask web开发的相关博文学习
  7. 跳转类内方法快捷键_想要快速编写代码,你得熟悉这些快捷键!
  8. 百度编辑器ueditor 字符限制
  9. python语言开发平台_Go+Python双语言混合开发
  10. ssis zip压缩文件_SSIS平面文件与原始文件
  11. 大数据:技术与应用实践指南
  12. 五、移动端技术解决方案
  13. 解决jdk证书问题-生成jssecacerts PKIX path building failed
  14. Python编程工具IDLE快捷键
  15. 怎样让私服服务器彻底崩溃
  16. 区块链中的POW是什么
  17. Photoshop制作3D水晶按钮
  18. 概率论与数理统计基础概念与重要定义汇总
  19. 1.10 新概念 have a cold/headache
  20. C语言之利用文件保存数据

热门文章

  1. 解决数据库插入中文变问号问题
  2. 60进制计数器的设计
  3. php实现mysql分表,php实现的mysql分表方案(水平切分)
  4. 坐标系转换--二维四参数大地坐标系转换模型变换关系理解
  5. 轻松学习JavaScript二十七:DOM编程学习之事件模型
  6. Mysql面试基础知识(全)
  7. 为什么要选择ABBYY FineReader 14
  8. Unity 可视化编辑工具 树节点 Tree Node Editor 四
  9. 【工具推荐】Eclipse 注释/取消注释 快捷键
  10. 趣谈HmacSHA1和原生SHA1的区别