Elaxia的路线
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的路线的更多相关文章
- BZOJ-1880 Elaxia的路线 SPFA+枚举
1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 921 Solved: 354 [Submit][Sta ...
- BZOJ 1880: [Sdoi2009]Elaxia的路线( 最短路 + dp )
找出同时在他们最短路上的边(dijkstra + dfs), 组成新图, 新图DAG的最长路就是答案...因为两人走同一条路但是不同方向也可以, 所以要把一种一个的s,t换一下再更新一次答案 ---- ...
- 【BZOJ1880】[Sdoi2009]Elaxia的路线(最短路)
[BZOJ1880][Sdoi2009]Elaxia的路线(最短路) 题面 BZOJ 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...
- 洛谷 P2149 [SDOI2009]Elaxia的路线 解题报告
P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia ...
- P2149 Elaxia的路线
P2149 Elaxia的路线 题意简述: 在一个n(n<=1500)个点的无向图里找两对点之间的最短路径的最长重合部分,即在保证最短路的情况下两条路径的最长重合长度(最短路不为一) 思路: 两 ...
- 【BZOJ 1880】 [Sdoi2009]Elaxia的路线 (最短路树)
1880: [Sdoi2009]Elaxia的路线 Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. ...
- BZOJ1880: [Sdoi2009]Elaxia的路线(最短路)
1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2049 Solved: 805 题目链接:https ...
- 【BZOJ1880】[SDOI2009]Elaxia的路线 (最短路+拓扑排序)
[SDOI2009]Elaxia的路线 题目描述 最近,\(Elaxia\)和\(w**\)的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. \(El ...
- 【BZOJ1880】[Sdoi2009]Elaxia的路线 最短路+DP
[BZOJ1880][Sdoi2009]Elaxia的路线 Description 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起 ...
随机推荐
- java继承初级
总结:重写方法,方法体内容不同. 还有子类都不能加public.它表示公共,一个程序只能有一个公共类 package com.sa; public class Ac { public void rea ...
- HDFS之四:HDFS原理解析(总体架构,读写操作流程)
前言 HDFS 是一个能够面向大规模数据使用的,可进行扩展的文件存储与传递系统.是一种允许文件通过网络在多台主机上分享的文件系统,可让多机器上的多用户分享文件和 存储空间.让实际上是通过网络来访问文件 ...
- AngularJS:HTML DOM
ylbtech-AngularJS:HTML DOM 1.返回顶部 1. AngularJS HTML DOM AngularJS 为 HTML DOM 元素的属性提供了绑定应用数据的指令. ng-d ...
- Java连接mysql数据库攻略
一. 软件下载 Mysql 下载版本:4.1.11 http://dev.mysql.com/downloads/mysql/4.1.html JDBC驱动 下载版本:3.1.8 http://dev ...
- 【新手向】Centos系统文件权限的系统阐述与演示
在linux服务器日常管理中,我们会经常管理查看文件或者文件夹的权限内容以保证服务的正常运行.今天就和大家聊聊文件权限的那些事. 查看文件的权限情况可以用 ll 命令例: ll -d /kid #查看 ...
- SqlServer——事务—隔离级别
隔离实际上是通过锁来实现的,作用于整个事务,它通常在事务开始前指定,如 SET TRANSACTION ISOLATION LEVEL READ Committed,指定后面的事务为 已提交读:而锁是 ...
- 通过XmlSerializer接口来生成xml文件
xml文件我们可以用来保存一些数据.例如用来备份短信.这个例子中,我们就用XmlSerializer接口来实现一个备份短信的程序.当然了,为了程序简单化,这个程序我们并不是真的去备份短信.我们通过一个 ...
- 基于ActiveMQ的Topic的数据同步——初步实现
一.背景介绍 公司自成立以来,一直以做项目为主,算是经累经验吧,自去年以来,我们部门准备将以前的项目做成产品,大概细分了几个小的产品,部们下面又分了几个团队,分别负责产品的研发,而我们属于平台团队,负 ...
- 运行程序显示:Could not find version 8.3 of the MCR.
- Struts2 结合 Freemarker 实例
Freemarker 是一个不依赖 web 容器的模板引擎,一个基于模板生成文本输出的工具.其工作的原理如下图: freemarker 不是一个 web 应用的框架,而适合作为 web 应用的一个组 ...