Elaxia的路线

求无向图中,两对点间最短路的最长公共路径。

四遍spfa标出每条边的标记,然后用拓扑排序跑dp即可。

exp:拓扑排序可以跑DAG上的dp。

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int maxn=1505;
struct Edge{
int fr, to, nxt, v, m1, m2;
}e[maxn*maxn*2];
int cnte=1, fir[maxn];
void addedge(int x, int y, int z){
Edge &ed=e[++cnte];
ed.fr=x; ed.to=y; ed.nxt=fir[x];
ed.v=z; fir[x]=cnte;
} //spfa 边要开成4n!
int n, m, dis1[maxn], dis2[maxn], q[maxn*maxn], h, t;
void spfa(int src, int dst, int *dis){
memset(dis, 0x3f3f, maxn*4); dis[src]=h=t=0;
q[t++]=src; int u, v;
while (h<t){
u=q[h++];
for (int i=fir[u]; i; i=e[i].nxt){
v=e[i].to;
if (dis[u]+e[i].v<dis[v])
dis[v]=dis[u]+e[i].v, q[t++]=v;
}
}
} int in[maxn], f[maxn]; int main(){
scanf("%d%d", &n, &m); int x, y, z;
int s1, t1, s2, t2;
scanf("%d%d%d%d", &s1, &t1, &s2, &t2);
for (int i=1; i<=m; ++i){
scanf("%d%d%d", &x, &y, &z);
addedge(x, y, z); addedge(y, x, z); }
spfa(s1, t1, dis1); spfa(t1, s1, dis2);
int minm=dis1[t1]; //最短路的长度
for (int i=2; i<=cnte; ++i){
if (dis1[e[i].fr]+dis2[e[i].to]+e[i].v==minm)
e[i].m1=1;
if (e[i].m1) ++in[e[i].to]; //若边在新图中
}
spfa(s2, t2, dis1); spfa(t2, s2, dis2);
minm=dis1[t2]; //最短路的长度
for (int i=2; i<=cnte; ++i)
if (dis1[e[i].fr]+dis2[e[i].to]+e[i].v==minm)
e[i].m2=e[i^1].m2=1; //两边都要标
h=t=0; int u, v;
for (int i=1; i<=n; ++i) if (!in[i]) q[t++]=i;
while (h<t){
u=q[h++];
for (int i=fir[u]; i; i=e[i].nxt){
if (!e[i].m1) continue; //必须在新图中
v=e[i].to; --in[v];
if (!in[v]) q[t++]=v;
f[v]=max(f[v], f[u]+(e[i].m2?e[i].v:0));
}
}
printf("%d\n", f[t1]);
return 0;
}

Elaxia的路线的更多相关文章

  1. BZOJ-1880 Elaxia的路线 SPFA+枚举

    1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 921 Solved: 354 [Submit][Sta ...

  2. BZOJ 1880: [Sdoi2009]Elaxia的路线( 最短路 + dp )

    找出同时在他们最短路上的边(dijkstra + dfs), 组成新图, 新图DAG的最长路就是答案...因为两人走同一条路但是不同方向也可以, 所以要把一种一个的s,t换一下再更新一次答案 ---- ...

  3. 【BZOJ1880】[Sdoi2009]Elaxia的路线(最短路)

    [BZOJ1880][Sdoi2009]Elaxia的路线(最短路) 题面 BZOJ 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...

  4. 洛谷 P2149 [SDOI2009]Elaxia的路线 解题报告

    P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia ...

  5. P2149 Elaxia的路线

    P2149 Elaxia的路线 题意简述: 在一个n(n<=1500)个点的无向图里找两对点之间的最短路径的最长重合部分,即在保证最短路的情况下两条路径的最长重合长度(最短路不为一) 思路: 两 ...

  6. 【BZOJ 1880】 [Sdoi2009]Elaxia的路线 (最短路树)

    1880: [Sdoi2009]Elaxia的路线 Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. ...

  7. BZOJ1880: [Sdoi2009]Elaxia的路线(最短路)

    1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 2049  Solved: 805 题目链接:https ...

  8. 【BZOJ1880】[SDOI2009]Elaxia的路线 (最短路+拓扑排序)

    [SDOI2009]Elaxia的路线 题目描述 最近,\(Elaxia\)和\(w**\)的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. \(El ...

  9. 【BZOJ1880】[Sdoi2009]Elaxia的路线 最短路+DP

    [BZOJ1880][Sdoi2009]Elaxia的路线 Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起 ...

随机推荐

  1. SQL子查询/嵌套查询

    sql子查询 嵌套SELECT语句 嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询不但能够出现在Where子句中,也能够出现在from子句中,作为 ...

  2. who命令参数及用法详解(linux查看在线用户命令)

    功能说明:显示目前登入系统的用户信息.  语 法:who [-Himqsw][--help][--version][am i][记录文件]  补充说明:执行这项指令可得知目前有那些用户登入系统,单独执 ...

  3. 修改rbd指定位置的数据

    标签(空格分隔): ceph,ceph实验 --- 我们通过查看index为0x01的小4M文件,得知了file2.txt这个文件内容在这个4M内保存的位置为0x9000,因为0x01前面还有一个4M ...

  4. Sass和Less、Stylus的转译和语法(1)

    四.Sass.LESS和Stylus转译成CSSSass.LESS和Stylus源文件(除了LESS源文件在客户端下运行之外)都不能直接被浏览器直接识别,这样一来,要正常的使用这些源文 件,就需要将其 ...

  5. 第 十五 课 Go 语言范围(Range)

    Go 语言中 range 关键字用于 for 循环中迭代数组(array).切片(slice).通道(channel)或集合(map)的元素 package main import "fmt ...

  6. Windows_Server_2008远程桌面多用户登陆的配置方法

    开启远程桌面后,Windows Vista(或Windows 2008)下默认只支持一个administrator用户登陆,一个登录后另一个就被踢掉了,下面提供允许同一个用户名同时多个用户登录的配置方 ...

  7. libstdc++.so.6

    libstdc++.so.6遇到的问题: 1.提示version `GLIBCXX_3.4.14' not found /usr/lib64/libstdc++.so.: version `GLIBC ...

  8. mysql使用存储过程插入数据后,参数为中文的为?或乱码

    最近了解了一下mysql存储过程,之前版本的mysql不支持存储过程,5.0版本后就可以支持存储过程的使用:恰好笔者下载使用版本为5.6.20: 做了一个给表插入数据的简单存储过程,发现打开表后汉字全 ...

  9. apache server和tomcat集群配置三:水平集群下的tomcat集群配置

    在jsp文件中加入以下代码,用来测试是否共享session: SessionID: <%= session.getId() %> 之前尝试在linux中,但是因为模拟环境是虚拟机,虚拟机只 ...

  10. Codeforces #505(div1+div2) B Weakened Common Divisor

    题意:给你若干个数对,每个数对中可以选择一个个元素,问是否存在一种选择,使得这些数的GCD大于1? 思路:可以把每个数对的元素乘起来,然后求gcd,这样可以直接把所有元素中可能的GCD求出来,从小到大 ...