bzoj1880: [Sdoi2009]Elaxia的路线(spfa,拓扑排序最长路)
1880: [Sdoi2009]Elaxia的路线
Time Limit: 4 Sec Memory Limit: 64 MB
Submit: 1944 Solved: 759
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 6 7 8
1 2 1
2 5 2
2 3 3
3 4 2
3 9 5
4 5 3
4 6 4
4 7 2
5 8 1
7 9 1
Sample Output
HINT
对于30%的数据,N ≤ 100;
对于60%的数据,N ≤ 1000;
对于100%的数据,N ≤ 1500,输入数据保证没有重边和自环。
Source
/*
如何求两对点最短路的最长公共路径?
开始的想法是对两个起点spfa,但对于如何求多条最短路经过的所有点没有思路
注意到其实本质是求最长路,只是需要一个图......
正解是4遍spfa,若某条边满足起点和终点分别到这条边最短路+这条路长等于起点到终点的最短路
那么这条边一定在最短路上。
所以就可以把1,2最短路径都经过的边重建图(注意若某条边不是被同向经过也要算)
这就有图了...求最长路即可(显然图是DAG 拓扑排序可以求)。
*/
#include<bits/stdc++.h> #define N 2005
#define M 1000007
#define inf 0x3f3f3f3f using namespace std;
struct node{
int u,v,w,nxt,f;
}e[M<<],E[M<<];
queue<int>q;
int n,m,cnt,cnt2;
int head[N],p[],d[][N],Head[N];
int in[N],f[N],v[N]; void add(int u,int v,int w)
{
e[++cnt].u=u;e[cnt].v=v;e[cnt].w=w;
e[cnt].nxt=head[u]; head[u]=cnt;
} void add_(int u,int v,int w)
{
E[++cnt2].u=u;E[cnt2].v=v;E[cnt2].w=w;
E[cnt2].nxt=Head[u]; Head[u]=cnt2;
} void spfa(int x)
{
memset(v,,sizeof v);
for(int i=;i<=n;++i) if(i!=p[x]) d[x][i]=inf;
q.push(p[x]);v[p[x]]=;
while(!q.empty())
{
int now=q.front();q.pop();v[now]=;
for(int i=head[now];i;i=e[i].nxt)
{
int to=e[i].v;
if(d[x][to]>d[x][now]+e[i].w)
{
d[x][to]=d[x][now]+e[i].w;
if(!v[to]) v[to]=,q.push(to);
}
}
}
} void rebuild()
{
for(int i=;i<=cnt;++i)
if(d[][e[i].u]+e[i].w+d[][e[i].v]==d[][p[]])
{
add_(e[i].u,e[i].v,e[i].w);
if(d[][e[i].u]+e[i].w+d[][e[i].v]==d[][p[]] || d[][e[i].u]+e[i].w+d[][e[i].v]==d[][p[]])
E[cnt2].f=;
in[e[i].v]++;
}
} void Tsort()
{
while(!q.empty()) q.pop();
q.push(p[]);
int now;
while(!q.empty())
{
now=q.front(); q.pop();
for(int i=Head[now];i;i=E[i].nxt)
{
--in[E[i].v];
if(!in[E[i].v])
{
q.push(E[i].v);
f[E[i].v]=max(f[E[i].v],f[now]+E[i].w*E[i].f);
}
}
}
} int main()
{
int x,y,z;
scanf("%d%d",&n,&m);
for(int i=;i<=;++i) scanf("%d",&p[i]);
for(int i=;i<=m;++i)
{
scanf("%d%d%d",&x,&y,&z);
add(x,y,z),add(y,x,z);
}
for(int i=;i<=;++i) spfa(i);
rebuild();
Tsort();
printf("%d",f[p[]]);
return ;
}
bzoj1880: [Sdoi2009]Elaxia的路线(spfa,拓扑排序最长路)的更多相关文章
- [BZOJ1880] [Sdoi2009] Elaxia的路线 (SPFA & 拓扑排序)
Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w**每天都要奔波于宿舍和实验室之间, ...
- [luogu2149][bzoj1880][SDOI2009]Elaxia的路线【拓扑排序+最短路+DP】
题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia和w每天都要奔波于宿舍和实验室之间,他们 希望在节约时间 ...
- BZOJ1880: [Sdoi2009]Elaxia的路线(最短路)
1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2049 Solved: 805 题目链接:https ...
- BZOJ1880:[SDOI2009]Elaxia的路线(最短路,拓扑排序)
Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w**每天都要奔波于宿舍和实验室之间, ...
- BZOJ1880: [Sdoi2009]Elaxia的路线
题意:求最短路最长公共距离. 考虑每一条边,如果满足dis(s1,u)+len+dis(v,t1)==dis(s1,t1) && dis(s2,u)+len+dis(v,t2)==di ...
- BZOJ1880 [Sdoi2009]Elaxia的路线 【最短路 + dp】
题目 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w每天都要奔波于宿舍和实验室之间,他们 希望在节约时间的前提 ...
- 【BZOJ1880】[SDOI2009]Elaxia的路线 (最短路+拓扑排序)
[SDOI2009]Elaxia的路线 题目描述 最近,\(Elaxia\)和\(w**\)的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. \(El ...
- BZOJ-1880 Elaxia的路线 SPFA+枚举
1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 921 Solved: 354 [Submit][Sta ...
- 【BZOJ1880】[Sdoi2009]Elaxia的路线(最短路)
[BZOJ1880][Sdoi2009]Elaxia的路线(最短路) 题面 BZOJ 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...
随机推荐
- [BZOJ2667][cqoi2012]模拟工厂
[BZOJ2667][cqoi2012]模拟工厂 试题描述 有一个称为“模拟工厂”的游戏是这样的:在时刻0,工厂的生产力等于1.在每个时刻,你可以提高生产力或者生产商品.如果选择提高生产力,在下一个时 ...
- http post提交数组
方式一:@RequestParam方式 服务提供方用@RequestParam注解接收参数,参数类型为long数组: @ApiOperation(value = "***", ta ...
- Sumdiv(poj1845)
题意:求A^B的因子的和. /* 首先将A分解 A=p1^a1*p2^a2*...*pn*an A^B=p1^a1B*p2^a2B*...*pn*anB 因子之和sum=(1+p1+p1^2+...+ ...
- 调用系统文件管理器选择图片,调用系统裁剪AIP对图片处理,显示裁剪之后的图片
package com.pingyijinren.test; import android.annotation.TargetApi; import android.app.Notification; ...
- 18.10.7 POIN 模拟赛
期望 :80+ +90+40=210+ 实际 :30+90+0=120 链接:https://www.nowcoder.com/acm/contest/175/A来源:牛客网 时间限制:C/C++ 1 ...
- Ubuntu 16.04安装Markdown编辑器MarkMyWords
继上一篇文章http://www.cnblogs.com/EasonJim/p/7119345.html中使用Sublime Text 3进行Markdown的编辑,总觉得操作上比较繁琐,现在推荐使用 ...
- 爱普生L201
http://tech.sina.com.cn/b/2011-03-29/05481698131.shtml
- hadoop 文件操作
Create a directory in HDFS - mkdir The hadoop mkdir command is for creating directories in the hdfs. ...
- poj3511--A Simple Problem with Integers(线段树求和)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 60441 ...
- [TypeScript] Define Custom Type Guard Functions in TypeScript
One aspect of control flow based type analysis is that the TypeScript compiler narrows the type of a ...