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**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起 ...
随机推荐
- 【转】LTE 全过程流程
LTE 过程全流程 1. UE处于关闭状态 2. 打开UE电源. 3. 搜索附近的频率 4. 同步时间 5. 小区搜索 6. 小区选择 7. 解码MIB 8. 解码SIB 9. 初始化RACH过程 1 ...
- RCE、exp、Exploit、Exploit Pack、exp-gui、Payload、MetaSploit都是啥
对于走在安全路上的小菜来说,这几个exp.Exploit.Exploit Pack.exp-gui.Payload.MetaSploit名词着实把人转的不轻,下面给大家解释下: RCE,remote ...
- POJ 1276 Cash Machine(单调队列优化多重背包)
Cash Machine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 38986 Accepted: 14186 De ...
- MySQL binlog 自动备份脚本
MySQL binlog 自动备份脚本 1 利用shell进行备份 #!/bin/sh #mysql binlog backup script /usr/local/mysql/bin/mysqlad ...
- ECS Windows系统使用自带监视器查看IIS并发连接数
问题现象 ECS Windows系统如何查看IIS并发连接数? 解决方案 1.运行-->输入“perfmon.msc” . 2.在“系统监视器”图表区域里点击右键,然后点“添加计数器”. 3.在 ...
- appium_python_android测试环境搭建
第一步 安装appium •Appium是由.NET 开发的,所以,它会依赖 .NET framework相关组件,所以先安装.net framework 4.5,备注: Appium最低支持.ne ...
- 用Nmap检测漏洞
介绍两个NSE脚本,可以检测CVE漏洞 nmap-vulners:https://github.com/vulnersCom/nmap-vulners vulscan:https://github.c ...
- 第一章 深入Web请求过程(待续)
B/S网络架构概述 如何发起一个请求 HTTP解析 DNS域名解析 CDN工作机制
- hibernate学习笔记(2)持久化类测试
持久化类的创建: 创建一个共有的不带参数的构造方法: public void Students(){ } 创建一个带参数的构造方法: (快捷键创建) 生成get,set方法: *可以不用此方法创建持久 ...
- Web访问中的角色与协议