HDU Today--hdu2112
HDU Today
Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 19680    Accepted Submission(s): 4632
这样住了一段时间,徐总对当地的交通还是不太了解。有时很郁闷,想去一个地方又不知道应该乘什么公交车,在什么地方转车,在什么地方下车(其实徐总自己有车,却一定要与民同乐,这就是徐总的性格)。
徐总经常会问蹩脚的英文问路:“Can you help me?”。看着他那迷茫而又无助的眼神,热心的你能帮帮他吗?
请帮助他用最短的时间到达目的地(假设每一路公交车都只在起点站和终点站停,而且随时都会开)。
第二行有徐总的所在地start,他的目的地end;
接着有n行,每行有站名s,站名e,以及从s到e的时间整数t(0<t<100)(每个地名是一个长度不超过30的字符串)。
note:一组数据中地名数不会超过150个。
如果N==-1,表示输入结束。
The best route is:
xiasha->ShoppingCenterofHangZhou->supermarket->westlake
虽然偶尔会迷路,但是因为有了你的帮助
**和**从此还是过上了幸福的生活。
――全剧终――
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#include<string>
#define MAX 0x3f3f3f3f
using namespace std;
int ma[][];
int d[],n,t;
void dijkstra()
{
int i,j,min,mark,used[];
for(i=;i<=t;i++)
{
used[i]=;
d[i]=ma[][i];
}
d[]=;
used[]=;
for(i=;i<=t;i++)
{
mark=-;
min=MAX;
for(j=;j<=t;j++)
{
if(!used[j]&&d[j]<min)
{
min=d[j];
mark=j;
}
}
if(mark==-)
break;
used[mark]=;
for(j=;j<=t;j++)
{
if(!used[j]&&d[j]>d[mark]+ma[mark][j])
d[j]=d[mark]+ma[mark][j];
}
}
} int main()
{
int i;
char s1[],s2[];
map<string,int> q;
while(scanf("%d",&n),n!=-)
{
memset(ma,MAX,sizeof(ma));
q.clear();
scanf("%s%s",s1,s2);
q[s1]=;
q[s2]=;
int flag=,a;
if(strcmp(s1,s2)==)
flag=1;//起点终点相同标记下,一会输出0 t=;
for(i=;i<n;i++)
{
scanf("%s%s%d",s1,s2,&a);
if(!q[s1]) q[s1]=t++;
if(!q[s2]) q[s2]=t++;//转化为数字过程
ma[q[s1]][q[s2]]=ma[q[s2]][q[s1]]=a;
}
dijkstra();
if(flag)
printf("0\n");
else if(d[]==MAX)
printf("-1\n");
else
printf("%d\n",d[]);
}
return ;
}
HDU Today--hdu2112的更多相关文章
- HDU Tody HDU2112
		不想用floyd了 也不一定适合 floyd只能处理小数据 dijkstra算法 wa了很久 一个是dijkstra里面的u 导致RE了无数次 下标溢出 还有就是注意细节 当起点和终点 ... 
- HDU2112 HDU Today 最短路+字符串哈希
		HDU Today Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ... 
- hdu2112(HDU Today  简单最短路)
		Problem Description 经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强.这时候,XHD ... 
- hdu2112  HDU Today
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目分类:SPFA算法+map容器 错误点:红色标记部分 代码: #include<bit ... 
- Hdu-2112 HDU Today (单源多点最短路——Dijsktra算法)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目大意:给你N个公交车站,起点,终点,各站之间的距离,求起点到终点之间的最短距离.(起点终点相 ... 
- hdu-2112 HDU Today---dijkstra+标号
		题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2112. 题目大意: 求起点到终点的最短路 解题思路: 对地名进行编号即可 然后直接dijkstra算 ... 
- hdu2112 HDU Today  基础最短路
		这题的关键是把车站的名字转化为点的编号.我用的是map.声明一个map<string,int> st,然后按照字符串出现的次序给st赋值.例如:st[s1]=2;代表这字符串s1出现的次序 ... 
- HDOJ 2111. Saving HDU 贪心 结构体排序
		Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- 【HDU 3037】Saving Beans Lucas定理模板
		http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ... 
- hdu 4859 海岸线 Bestcoder Round 1
		http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ... 
随机推荐
- IOC容器MEF在MVC中的使用
			最近想把自己的网站框架用IOC改造下,经过对比,我初步选择autofac,虽然MEF不需要配置,但性能不行,autofac虽然需要自己写自动化注入,但性能非常好. 先分析下各大IOC框架的性能,分两类 ... 
- 修改UITextField Placeholder的颜色
			修改UITextField Placeholder的颜色 1 第一种情况只是修改颜色等文字属性 创建属性字典 NSDictionary *attrsDic = @{ NSForegroundColor ... 
- 设置ListView每条数据之间的间隔
			1:如果不需要分割线可以在xml布局文件中ListView下设置XML属性: android:divider="#00000000" android:dividerHeight=& ... 
- Flash AIR 保存与读取
			package { import flash.display.Sprite; import flash.net.URLLoader; import flash.display.Loader; impo ... 
- cf437C The Child and Toy
			C. The Child and Toy time limit per test 1 second memory limit per test 256 megabytes input standard ... 
- Raid1源代码分析--初始化流程
			初始化流程代码量比较少,也比较简单.主要是run函数.(我阅读的代码的linux内核版本是2.6.32.61) 四.初始化流程分析 run函数顾名思义,很简单这就是在RAID1开始运行时调用,进行一些 ... 
- 好多邮箱的SMTP设置
			http://731771490.diandian.com/post/2011-04-20/19576550 
- fcntl函数加文件锁
			对文件加锁是原子性的,可以用于进程间文件操作的同步.在linux下,有三个函数可以对文件进程加锁,分别是fcntl.flock.lockf.这里只说fcntl,它的用法也是最复杂的. fcntl是fi ... 
- ubuntu14.04 + cocos2d-x-3.6 + eclipse发布android
			cocos2d-x-2.2.6版本 :http://www.cnblogs.com/weishuan/p/4698470.html 接下来是3.6了 ,准备好下面四个东东,我把这些都放在XXX/App ... 
- banner背景通栏
			background: #76CEF6 url("../images/bg.jpg") repeat-x 0 0; -webkit-background-size: 100%; ... 
