您的位置:首页 > 其它

洛谷1186-玛丽卡

2016-09-19 10:23 302 查看
玛丽卡

题目描述

麦克找了个新女朋友,玛丽卡对他非常恼火并伺机报复。

因为她和他们不住在同一个城市,因此她开始准备她的长途旅行。

在这个国家中每两个城市之间最多只有一条路相通,并且我们知道从一个城市到另一个城市路上所需花费的时间。

麦克在车中无意中听到有一条路正在维修,并且那儿正堵车,但没听清楚到底是哪一条路。无论哪一条路正在维修,从玛丽卡所在的城市都能到达麦克所在的城市。

玛丽卡将只从不堵车的路上通过,并且她将按最短路线行车。麦克希望知道在最糟糕的情况下玛丽卡到达他所在的城市需要多长时间,这样他就能保证他的女朋友离开该城市足够远。

编写程序,帮助麦克找出玛丽卡按最短路线通过不堵车道路到达他所在城市所需的最长时间(用分钟表示)。

输入格式

第一行有两个用空格隔开的数N和M,分别表示城市的数量以及城市间道路的数量。1≤N≤1000,1≤M≤N*(N-1)/2。城市用数字1至N标识,麦克在城市1中,玛丽卡在城市N中。

接下来的M行中每行包含三个用空格隔开的数A,B和V。其中1≤A,B≤N,1≤V≤1000。这些数字表示在A和城市B中间有一条双行道,并且在V分钟内是就能通过。

输出格式

输出文件的第一行中写出用分钟表示的最长时间,在这段时间中,无论哪条路在堵车,玛丽卡应该能够到达麦克处,如果少于这个时间的话,则必定存在一条路,该条路一旦堵车,玛丽卡就不能够赶到麦克处。

Input

5 7

1 2 8

1 4 10

2 3 9

2 4 10

2 5 1

3 4 7

3 5 10

-

Output

27

-

题解:

先SPFA求出最短路,然后枚举去掉哪条边,再跑n次最短路,记录结果得出最大的方案。

代码:

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;

struct node
{
int from,to,next,v,flag;
}e[1001*1001];
int n,m,head[1010],pre[1010],cnt,dis[1010];
bool vis[1010];

inline void add(int u,int v,int w)
{
cnt++;
e[cnt].from=u;
e[cnt].to=v;
e[cnt].v=w;
e[cnt].next=head[u];
head[u]=cnt;
}

void spfa1(int s)
{
memset(vis,0,sizeof(vis));
memset(pre,0,sizeof(pre));
memset(dis,0x3f,sizeof(dis));
queue<int>q;
dis[s]=0;
vis[s]=true;
q.push(s);
while(!q.empty())
{
int t=q.front();
q.pop();
vis[t]=false;
for(int i=head[t];i;i=e[i].next)
{
int temp=e[i].to;
if(dis[temp]>dis[t]+e[i].v)
{
dis[temp]=dis[t]+e[i].v;
pre[temp]=i;
if(!vis[temp])
{
vis[temp]=true;
q.push(temp);
}
}
}
}
}
void spfa2(int s)
{
memset(vis,0,sizeof(vis));
memset(pre,0,sizeof(pre));
memset(dis,0x3f,sizeof(dis));
queue<int>q;
dis[s]=0;
vis[s]=true;
q.push(s);
while(!q.empty())
{
int t=q.front();
q.pop();
vis[t]=false;
for(int i=head[t];i;i=e[i].next)
{
int temp=e[i].to;
if(dis[temp]>dis[t]+e[i].v&&e[i].flag!=1)
{
dis[temp]=dis[t]+e[i].v;
pre[temp]=i;
if(!vis[temp])
{
vis[temp]=true;
q.push(temp);
}
}
}
}
}

int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);add(v,u,w);
}
spfa1(n);
int ans=0;
for(int i=pre[1];i;i=pre[e[i].from])
{
e[i].flag=1;
spfa2(n);
ans=max(ans,dis[1]);
e[i].flag=0;
}
printf("%d\n",ans);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  最短路