CSU 1808 - 地铁 - [最短路变形]
题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1808
Time limit: 5000 ms Memory limit: 131072 kB
Bobo 居住在大城市 ICPCCamp。
Input
Output
对于每组数据,输出一个整数表示要求的值。
Sample Input
3 3
1 2 1 1
2 3 2 1
1 3 1 1
3 3
1 2 1 1
2 3 2 1
1 3 1 10
3 2
1 2 1 1
2 3 1 1
Sample Output
1
3
2
题解:
如果只记录到某个节点x的最短路长度d[x],并且记录对应于d[x],是坐哪号线来到节点x的,这样显然是错误的。
原因比如这样的样例:
3 3
1 2 1 2
1 2 3 3
2 3 3 5
可以看出,d[x]要扩展到d[x][c],即这题的状态有两个量决定:到了节点x,最后乘坐的是c号线;
那么,如果我们把节点x用若干条边Edge(u1→x)…Edge(uk→x)来代替,那么我们就相当于把d[x]要扩展到d[x][c]了;
所以我们可以直接把边当成点,对边做最短路。
(这题对边做最短路,如果用spfa的话会TLE,要使用堆优化dijkstra)
AC代码:
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long LL;
typedef pair<LL,int> Pair; const LL INF=1e18;
const int maxn=1e5+;
const int maxm=2e5+; //无向边拆成两条有向边 int n,m; struct Edge{
int u,v,c;
int next;
LL t;
};
Edge E[maxm];
int head[maxn],ne;
void init()
{
ne=;
memset(head,-,sizeof(head));
}
void addedge(int u,int v,int c,LL t)
{
E[ne].u=u, E[ne].v=v, E[ne].c=c, E[ne].t=t;
E[ne].next=head[u];
head[u]=ne++;
} LL ans;
LL d[maxm];
bool vis[maxm];
void dijkstra(int st)
{
priority_queue< Pair, vector<Pair>, greater<Pair> > Q; memset(vis,,sizeof(vis));
for(int i=;i<ne;i++) d[i]=INF;
ans=INF; for(int i=head[st];i!=-;i=E[i].next)
{
d[i]=E[i].t;
Q.push(Pair(d[i],i));
}
while(!Q.empty())
{
int x=Q.top().second; Q.pop(); if(vis[x]) continue;
vis[x]=;
if(E[x].v==n) ans=min(ans,d[x]); for(int y=head[E[x].v];y!=-;y=E[y].next)
{
if(vis[y]) continue;
if(d[y]>d[x]+E[y].t+abs(E[y].c-E[x].c))
{
d[y]=d[x]+E[y].t+abs(E[y].c-E[x].c);
Q.push(Pair(d[y],y));
}
}
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
init();
for(int i=;i<=m;i++)
{
int u,v,c; LL t;
scanf("%d%d%d%lld",&u,&v,&c,&t);
addedge(u,v,c,t);
addedge(v,u,c,t);
} dijkstra();
printf("%lld\n",ans);
}
}
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long LL;
typedef pair<LL,int> Pair; const LL INF=1e18;
const int maxn=1e5+;
const int maxm=2e5+; //无向边拆成两条有向边 int n,m; struct Edge{
int u,v,c;
LL t;
};
vector<Edge> E;
vector<int> G[maxn];
void init(int l,int r)
{
E.clear();
for(int i=l;i<=r;i++) G[i].clear();
}
void addedge(int u,int v,int c,LL t)
{
E.push_back((Edge){u,v,c,t});
G[u].push_back(E.size()-);
} LL ans;
LL d[maxm];
bool vis[maxm];
void dijkstra(int st)
{
priority_queue< Pair, vector<Pair>, greater<Pair> > Q; memset(vis,,sizeof(vis));
for(int i=;i<E.size();i++) d[i]=INF;
ans=INF; for(int i=;i<G[st].size();i++)
{
int x=G[st][i];
d[x]=E[x].t;
Q.push(Pair(d[x],x));
}
while(!Q.empty())
{
int x=Q.top().second; Q.pop(); if(vis[x]) continue;
vis[x]=;
if(E[x].v==n) ans=min(ans,d[x]); for(int i=;i<G[E[x].v].size();i++)
{
int y=G[E[x].v][i];
if(vis[y]) continue;
if(d[y]>d[x]+E[y].t+abs(E[y].c-E[x].c))
{
d[y]=d[x]+E[y].t+abs(E[y].c-E[x].c);
Q.push(Pair(d[y],y));
}
}
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
init(,n);
for(int i=;i<=m;i++)
{
int u,v,c; LL t;
scanf("%d%d%d%lld",&u,&v,&c,&t);
addedge(u,v,c,t);
addedge(v,u,c,t);
} dijkstra();
printf("%lld\n",ans);
}
}
注:两份代码的区别是分别用链式前向星和vector邻接表存图。
CSU 1808 - 地铁 - [最短路变形]的更多相关文章
- CSU 1808: 地铁 最短路
题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1808 1808: 地铁 Time Limit: 5 SecMemory Limit: ...
- CSU 1808 地铁(最短路变形)
http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1808 题意: Bobo 居住在大城市 ICPCCamp. ICPCCamp 有 n 个地铁站, ...
- 【最短路】【STL】CSU 1808 地铁 (2016湖南省第十二届大学生计算机程序设计竞赛)
题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1808 题目大意: N个点M条无向边(N,M<=105),每条边属于某一条地铁Ci ...
- CSU 1808 地铁
题意: ICPCCamp 有 n 个地铁站,用 1,2,-,n 编号. m 段双向的地铁线路连接 n 个地铁站,其中第 i 段地铁属于 ci 号线,位于站 ai,bi 之间,往返均需要花费 ti 分钟 ...
- CSU 1808 地铁 (Dijkstra)
Description Bobo 居住在大城市 ICPCCamp. ICPCCamp 有 n 个地铁站,用 1,2,-,n 编号. m 段双向的地铁线路连接 n 个地铁站,其中第 i 段地铁属于 ci ...
- POJ-2253.Frogger.(求每条路径中最大值的最小值,最短路变形)
做到了这个题,感觉网上的博客是真的水,只有kuangbin大神一句话就点醒了我,所以我写这篇博客是为了让最短路的入门者尽快脱坑...... 本题思路:本题是最短路的变形,要求出最短路中的最大跳跃距离, ...
- POJ 3635 - Full Tank? - [最短路变形][手写二叉堆优化Dijkstra][配对堆优化Dijkstra]
题目链接:http://poj.org/problem?id=3635 题意题解等均参考:POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]. 一些口胡: ...
- POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]
题目链接:http://poj.org/problem?id=3635 Description After going through the receipts from your car trip ...
- POJ-1797Heavy Transportation,最短路变形,用dijkstra稍加修改就可以了;
Heavy Transportation Time Limit: 3000MS Memory Limit: 30000K Description Background Hugo ...
随机推荐
- iOS中js与objective-c的交互(转)
因为在iOS中没有WebKit.Framework这个库的,所以也就没有 windowScriptObject对象方法了.要是有这个的方法的话 就方便多了,(ps:MacOS中有貌似) 现在我们利用其 ...
- Java动态调用类中方法
在Java中,调用类的方法有两种方式:对于静态方法可以直接使用类名调用,对于非静态方法必须使用类的对象调用.反射机制提供了比较另类的调用方式,可以根据需要指定要调用的方法,而不必在编程时确定.调用的方 ...
- MySQL---循环语句
mysql 操作同样有循环语句操作,网上说有3中标准的循环方式: while 循环 . loop 循环和repeat循环.还有一种非标准的循环: goto. 鉴于goto 语句的跳跃性会造成使用的的思 ...
- 架设SVN服务器
服务器端:windows 2003 + subversion 下载地址:http://subversion.tigris.org/servlets/ProjectDocumentList?folder ...
- Druid连接池基本配置及监控配置
1.配置Druid连接池,监控慢sql <!-- 数据源配置, 使用 Druid 数据库连接池 --> <bean name="dataSource" class ...
- informix中的时间计算
今天看SUN服务器是的mail(vi /var/mail/xxxuser),发现定时任务上的一些存储过程执行有错误,其中有一个错误是long transaction,长事务错误,到数据库一查,天哪 ...
- ASP.NET MVC4优化
删除无用的视图引擎 默认情况下,ASP.NET MVCE同时支持WebForm和Razor引擎,而我们通常在同一个项目中只用到了一种视图引擎,如Razor,那么,我们就可以移除掉没有使用的视图引擎,提 ...
- Android学习之SeekBar(控制wav音频的声音)
使用SeekBar调节声音 SeekBar控件其实就是一个高级点的进度条,就像我们在听歌,看电影用的播放器上的进度条一样,是可以拖动的,可以改变进度的一个进度条控件! SeekBar常用属性: and ...
- Delphi应用程序的调试(六)步进式代码调试
步进式代码调试(Stepping Through Your Code) 步进式代码调试是最基本的调试操作之一,但仍要在此讲述.人们常常容易犯只见树木不见森林的错误.经常复习基本的知识有助于读者了解以前 ...
- C# 反射的深入了解
Assembly.Load("")的使用说明如下; 并不是命名空间.常用的是程序集名称,也就是dll的名称 关于反射Assembly.Load("程序集" ...