HDU Today

时间:2022-09-20 12:57:20

HDU Today

Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 143 Accepted Submission(s): 43
 
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 虽然偶尔会迷路,但是因为有了你的帮助
**和**从此还是过上了幸福的生活。 ――全剧终――
 
Author
lgx
 
Source
ACM程序设计_期末考试(时间已定!!)
 
Recommend
lcy
/*
最短路,但是就是输入方式有点麻烦的
*/
#include<bits/stdc++.h>
#define ll long long
#define INF 0x3f3f3f3f
using namespace std;
set<string >s;//用来存车站的号码
map<string,ll>m;
string x,y;//两个车站
string fis,en;//两个车站
ll mapn[][];
bool vis[];
ll d[];
ll n;
ll val;
ll f;
struct node
{
string u,v;
ll val;
node(){}
node(string a,string b,ll c)
{
u=a;
v=b;
val=c;
}
};
vector<node>edge;
set<string>::iterator it; //定义前向迭代器
void init()
{
edge.clear();
s.clear();
m.clear();
memset(mapn,INF,sizeof mapn);
memset(vis,false,sizeof vis);
memset(d,INF,sizeof d);
f=;
}
ll dijkstra()
{
//cout<<"ok"<<endl;
ll tmp,pt;
for(int i=;i<=n;i++)//进行初始化
d[i]=mapn[][i];
vis[]=;
d[]=;
for(int i=;i<=n;i++)
{
tmp=INF;//找到一个权值最小的点 for(int j=;j<=n;j++)
{
if(tmp>d[j]&&!vis[j])
{
tmp=d[j];
pt=j;
}
}
vis[pt]=;
for(int j=;j<=n;j++)
{
if(!vis[j])
d[j]=min(d[j],d[pt]+mapn[pt][j]);
}
}
return d[n];
}
int main()
{
//freopen("C:\\Users\\acer\\Desktop\\in.txt","r",stdin);
while(scanf("%lld",&n)!=EOF&&n!=-)
{
init();
cin>>fis>>en;
if(fis==en)
f=;
//m.insert(pair<string,ll>(fis,1));
for(int i=;i<n;i++)
{
cin>>x>>y>>val;
edge.push_back(node(x,y,val));
s.insert(x);s.insert(y);
}
if(f)//如果起终点相同的话就输出1
{
puts("");
continue;
}
if(s.find(fis)==s.end()||s.find(en)==s.end())//起终点下面没给出的不可能到达
{
puts("-1");
continue;
}
m.insert(pair<string,ll>(fis,));
n=;
//cout<<s.size()<<endl;
for(it=s.begin();it!=s.end();it++)
{
if(*it==en||*it==fis)
continue;
m.insert(pair<string,ll>(*it,n++));
}
m.insert(pair<string,ll>(en,n));
//cout<<n<<endl;
for(int i=;i<edge.size();i++)
{
if(mapn[m[edge[i].u]][m[edge[i].v]]>edge[i].val)
mapn[m[edge[i].u]][m[edge[i].v]]=mapn[m[edge[i].v]][m[edge[i].u]]=edge[i].val;
}
ll cur=dijkstra();
if(cur==INF)
puts("-1");
else
printf("%lld\n",cur);
}
return ;
}

HDU Today的更多相关文章

  1. HDOJ 2111&period; Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  2. 【HDU 3037】Saving Beans Lucas定理模板

    http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...

  3. hdu 4859 海岸线 Bestcoder Round 1

    http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...

  4. HDU 4569 Special equations&lpar;取模&rpar;

    Special equations Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  5. HDU 4006The kth great number&lpar;K大数 &plus;小顶堆&rpar;

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

  6. HDU 1796How many integers can you find(容斥原理)

    How many integers can you find Time Limit:5000MS     Memory Limit:32768KB     64bit IO Format:%I64d ...

  7. hdu 4481 Time travel&lpar;高斯求期望&rpar;&lpar;转&rpar;

    (转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...

  8. HDU 3791二叉搜索树解题&lpar;解题报告&rpar;

    1.题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=3791 2.参考解题 http://blog.csdn.net/u013447865/articl ...

  9. hdu 4329

    problem:http://acm.hdu.edu.cn/showproblem.php?pid=4329 题意:模拟  a.     p(r)=   R'/i   rel(r)=(1||0)  R ...

  10. HDU 2586

    http://acm.hdu.edu.cn/showproblem.php?pid=2586 题意:求最近祖先节点的权值和 思路:LCA Tarjan算法 #include <stdio.h&g ...

随机推荐

  1. Vijos P1459 车展 treap求任意区间中位数

    描述 遥控车是在是太漂亮了,韵韵的好朋友都想来参观,所以游乐园决定举办m次车展.车库里共有n辆车,从左到右依次编号为1,2,…,n,每辆车都有一个展台.刚开始每个展台都有一个唯一的高度h[i].主管已 ...

  2. sql按字段值进行统计

    用group by 如有个student表里有性别sex来统计 select sex,count(*) from student group by sex;

  3. Linux系统下查看硬件信息命令大全

    导读 有许多命令可以用来查看 Linux 系统上的硬件信息.有些命令只能够打印出像 CPU 和内存这一特定的硬件组件信息,另外一些命令可以查看多种硬件组件的信息. 这个教程可以带大家快速了解一下查看各 ...

  4. CentOS6&period;5安装telnet

    原文地址:http://www.cnblogs.com/zhongshengzhen/ 1.检查是否已经安装telnet [root@localhost ~]# rpm -qa | grep teln ...

  5. GCC内嵌汇编

    http://blog.csdn.net/mydo/article/details/8279924

  6. &lbrack;Lua&rsqb;索引极致,form&period;lua

    local form = {_tag = 'form'} function form.build(tag, super) local target = { _tag = tag, _super = s ...

  7. yii2&period;0 控制器方法 视图表单 Form表单处理

    假设我们在ArticleController.php下面的actionForm方法中来处理提交的表单 新建立一个 views/Article/article-form.php文件用来作为输入表单 &l ...

  8. android studio导入矢量svg图标技巧

    1.在android studio中打开File-->Settings-->Plugins,在Plugins中输入SVG2VectorDrawable搜索插件,并安装. 2.安装完成重启a ...

  9. fread读入优化,寻找速度极限

    序: 在之前的测试中,我们比较了四种读入方式,发现使用读入优化是最快的选择,但是我们知道fread()是比它更快的方法.这一次,我们对比四种读入优化,探寻C++读取速度的极限. 分别是getchar( ...

  10. c语言第五次作业--函数

    一.PTA实验作业 题目1.使用函数输出一个整数的逆序数 1.本题PTA提交列表 2.设计思路 1.int mod,rever:分别表示余数和返回的数 2.while(number%10 || num ...