hdu HDU Today2112
HDU Today
Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 21353 Accepted Submission(s): 5094
这样住了一段时间,徐总对当地的交通还是不太了解。有时很郁闷,想去一个地方又不知道应该乘什么公交车,在什么地方转车,在什么地方下车(其实徐总自己有车,却一定要与民同乐,这就是徐总的性格)。
徐总经常会问蹩脚的英文问路:“Can you help me?”。看着他那迷茫而又无助的眼神,热心的你能帮帮他吗?
请帮助他用最短的时间到达目的地(假设每一路公交车都只在起点站和终点站停,而且随时都会开)。
第二行有徐总的所在地start,他的目的地end;
接着有n行,每行有站名s,站名e,以及从s到e的时间整数t(0<t<100)(每个地名是一个长度不超过30的字符串)。
note:一组数据中地名数不会超过150个。
如果N==-1,表示输入结束。
#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相关推荐
- HDU hdu 2094 产生冠军 拓扑排序 判定环
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2094 对于是否有环,是通过一个N(节点数)的循环来判定.检查并更新每个节点的入度数. 每找到一个入度唯 ...
- Python爬虫之HDU提交数据
前一篇http://www.cnblogs.com/liyinggang/p/6094338.html 使用了爬虫爬取hdu 的代码,今天实现了将数据向hdu 提交的功能,接下来就是需要将两个功能合并 ...
- HDU - 2500 做一个正气的杭电人
OJ地址:https://vjudge.net/problem/HDU-2500 做人要有一身正气,杭电学子都应该如此.比如我们今天的考试就应该做到"诚信"为上. 每次考试的第一个 ...
- 做一个正气的杭电人 HDU
Time Limit : 1000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submission(s) ...
- HDOJ(HDU) 2500 做一个正气的杭电人(水~)
Problem Description 做人要有一身正气,杭电学子都应该如此.比如我们今天的考试就应该做到"诚信"为上. 每次考试的第一个题目总是很简单,今天也不例外,本题是要求输 ...
- 杭电OJ分类题目(1)
原题出处:HDOJ Problem Index by Type,http://acm.hdu.edu.cn/typeclass.php 杭电OJ分类题目(1) HDU Introduction HDU ...
- HDU2500 做一个正气的杭电人【水题】
做一个正气的杭电人 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- 2019.8.1 每周反思
第一次写这个每周反思呢...woc语文不好就是瞎jb写,但是个人认为还挺有意义的. 这周仿佛肝不太好,感觉刷题刷不动,题解也写不动,不知道为什么.是我不注意休息么?是我学习过度了么?我才13岁啊!(惊 ...
- 杭电ACM基础题(2201、2212、2304、2309、2317、2401、2500、2502、2503、1708、1161)
文章目录 2201.熊猫阿波的故事[概率问题] 2212.DFS[各位数的阶乘之和等于该数] 2304.Electrical Outlets[电源板接口] 2309.ICPC Score Totali ...
最新文章
- c++ lambda函数_C++ Lambda表达式
- 【计算机网络】传输层 : TCP 拥塞控制 ( 慢开始 | 拥塞避免 | 快重传 | 快恢复 )
- unity menuitem_Unity热更_打AssetBundles包
- grunt -- javascript自动化工具
- HDU4372 Count the Buildings
- flask web开发的相关博文学习
- 跳转类内方法快捷键_想要快速编写代码,你得熟悉这些快捷键!
- 百度编辑器ueditor 字符限制
- python语言开发平台_Go+Python双语言混合开发
- ssis zip压缩文件_SSIS平面文件与原始文件
- 大数据:技术与应用实践指南
- 五、移动端技术解决方案
- 解决jdk证书问题-生成jssecacerts PKIX path building failed
- Python编程工具IDLE快捷键
- 怎样让私服服务器彻底崩溃
- 区块链中的POW是什么
- Photoshop制作3D水晶按钮
- 概率论与数理统计基础概念与重要定义汇总
- 1.10 新概念 have a cold/headache
- C语言之利用文件保存数据