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. Linux驱动中获取系统时间

    最近在做VoIP方面的驱动,总共有16个FXS口和FXO口依次初始化,耗用的时间较多.准备将其改为多线程,首先需要确定哪个环节消耗的时间多,这就需要获取系统时间. #include <linux ...

  2. thrift rpc 使用常见问题解答和经验

    Thrift是一个非常棒的工具,是Facebook的开源项目,目前的开发非常的活跃,由Apache管理,所以用的是Apache Software License,这非常重要,因为可以放心的对其修改并用 ...

  3. python selenium 滚动条处理、页面拖动

    selenium中没有直接控制滚动条的方法,可以使用方法:execute_script(),可以直接执行js的脚本. 一.竖向滚动条控制,三种方法总有一款适合你. 1.滚动条拉到最底: js=&quo ...

  4. Java 的编译和运行机制

    创建一个 名为 test.java 的 Java 源文件 源代码: class Hello{ public static void main(String[] args) { System.out.p ...

  5. web编程的初步认识

    一直以后, 只知道打开浏览器, 输入网址便可以上网浏览网页, 但是当认真琢磨起这web编程的时候, 对于很多细节却是感觉很迷惑, 在慢慢的学习中, 才逐渐有了些了解. web有client/serve ...

  6. python 函数和方法的区别

    一.函数和方法的区别 1.函数要手动传self,方法不用传 2.如果是一个函数,用类名去调用,如果是一个额方法,用对象去调用 举例说明: class Foo(object): def __init__ ...

  7. 一个hitbernate配置文件,带几个表(注意mapping);如果连接字符串没有设置utf-8,向insert mysql 会产生乱码(utf8 或 utf-8)

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-configuratio ...

  8. DAY7-面向对象之多态与多态性

    一.多态 多态指的是一类事物有多种形态 动物有多种形态:人,狗,猪 import abc class Animal(metaclass=abc.ABCMeta): #同一类事物:动物 @abc.abs ...

  9. 用JS,做一个简单的计算器

    <!DOCTYPE html> <html> <head> <meta charset="utf-8">   <title&g ...

  10. Solr根据参考点的坐标来返回范围内的小区和距离

    @Test public void query() throws Exception{ SystemDefaultHttpClient httpClient = new SystemDefaultHt ...