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 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...
随机推荐
- Jmeter关联-获取token值
1. token就是令牌,比如你授权(登录)一个程序时,他就是个依据,判断你是否已经授权该软件:也叫关联 2. cookie就是写在客户端的一个txt文件,里面包括你登录信息之类的,这样你下次在登录某 ...
- 杜教筛--51nod1239 欧拉函数之和
求$\sum_{i=1}^{n}\varphi (i)$,$n\leqslant 1e10$. 这里先把杜教筛的一般套路贴一下: 要求$S(n)=\sum_{i=1}^{n}f(i)$,而现在有一数论 ...
- Our Journey of Dalian Ends 乌鲁木齐网络赛 最小费用最大流
Life is a journey, and the road we travel has twists and turns, which sometimes lead us to unexpecte ...
- Less Time, More profit 最大权闭合子图(最大流最小割)
The city planners plan to build N plants in the city which has M shops. Each shop needs products fro ...
- 用 字蛛 取出需要的字符应用字体 @font-face
一.安装font-spider npm install font-spider -g 二.目录结构 font-spider font FZZZHONGHJW.ttf font.html 三.font. ...
- 选择器的使用(first-child和last-child选择器)
<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta ...
- 选择器的使用(root选择器)
<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta ...
- Spring Boot实现跨域(转)
一.方法: 服务端设置Respone Header头中Access-Control-Allow-Origin 配合前台使用jsonp 继承WebMvcConfigurerAdapter 添加配置类 二 ...
- Eclipse 搭建tomcat+动态项目完整版
1. Tomcat搭建 1.新加服务器,右击控制台的server目录->new->server->选择本地tomcat 2.配置tomcat属性(如果更改失败,将tomcat下的项目 ...
- 程序猿Web面试之JSON
JSON是什么? JSON(JavaScript对象表示法), 是在网络通信下.经常使用的一种数据表达格式,它有助于我们于一个自描写叙述的,独立的和轻的方式呈现并交换数据. 这些数据能够易于和转 ...