[BZOJ1880] [Sdoi2009] Elaxia的路线 (SPFA & 拓扑排序)
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
Solution
补个条件:$m\leq 500000$
如果$dis_{s->u_i}+w_i=dis_{t->v_i}$,那么边$i$才可能成为答案
这些边组成的图一定是一个拓扑图,走一遍最长链即可。
其实主要的坑点在于因为是无向图,所以需要反着做一遍
也就是说,$x_1$->$y_1$和$y_2$->$x_2$的公共路径也可能是答案,也就是说,原题意是错的= =b
#include <bits/stdc++.h>
using namespace std;
struct edge
{
int v, w, nxt;
}e[];
int fst[][], dis[][], q[], indeg[];
int n, etot, sss1, ttt1, sss2, ttt2;
bool inq[]; void addedge(int *f, int u, int v, int w)
{
e[++etot] = (edge){v, w, f[u]}, f[u] = etot;
} bool check(int u, int i)
{
if(dis[][u] + e[i].w + dis[][e[i].v] != dis[][ttt1]) return false;
return dis[][u] + e[i].w + dis[][e[i].v] == dis[][ttt2];
} void SPFA(int sss, int *d)
{
int front = , back;
memset(d, , );
q[back = ] = sss, d[sss] = , inq[sss] = true;
while(front != back)
{
int u = q[++front & ];
front &= , inq[u] = false;
for(int i = fst[][u]; i; i = e[i].nxt)
if(d[e[i].v] > d[u] + e[i].w)
{
d[e[i].v] = d[u] + e[i].w;
if(!inq[e[i].v])
{
q[++back & ] = e[i].v;
back &= , inq[e[i].v] = true;
}
}
}
} int Topo_sort()
{
int front = , back = , ans = ;
for(int i = ; i <= n; ++i)
if(!indeg[i]) q[++back] = i;
while(front != back)
{
int u = q[++front];
for(int i = fst[][u]; i; i = e[i].nxt)
{
int v = e[i].v, w = e[i].w;
dis[][v] = max(dis[][v], dis[][u] + w);
if(!--indeg[e[i].v]) q[++back] = v;
}
}
for(int i = ; i <= n; ++i)
ans = max(ans, dis[][i]);
return ans;
} int main()
{
int m, u, v, w, ans;
scanf("%d%d", &n, &m);
scanf("%d%d%d%d", &sss1, &ttt1, &sss2, &ttt2);
for(int i = ; i <= m; ++i)
{
scanf("%d%d%d", &u, &v, &w);
addedge(fst[], u, v, w);
addedge(fst[], v, u, w);
}
SPFA(sss1, dis[]), SPFA(ttt1, dis[]);
SPFA(sss2, dis[]), SPFA(ttt2, dis[]);
for(int i = ; i <= n; ++i)
for(int j = fst[][i]; j; j = e[j].nxt)
if(check(i, j))
{
addedge(fst[], i, e[j].v, e[j].w);
++indeg[e[j].v];
}
ans = Topo_sort();
memset(fst[], , sizeof(fst[]));
memset(dis[], , sizeof(dis[]));
memset(indeg, , sizeof(indeg));
swap(sss2, ttt2);
SPFA(sss2, dis[]), SPFA(ttt2, dis[]);
for(int i = ; i <= n; ++i)
for(int j = fst[][i]; j; j = e[j].nxt)
if(check(i, j))
{
addedge(fst[], i, e[j].v, e[j].w);
++indeg[e[j].v];
}
ans = max(ans, Topo_sort());
printf("%d\n", ans);
return ;
}
[BZOJ1880] [Sdoi2009] Elaxia的路线 (SPFA & 拓扑排序)的更多相关文章
- bzoj1880: [Sdoi2009]Elaxia的路线(spfa,拓扑排序最长路)
1880: [Sdoi2009]Elaxia的路线 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 1944 Solved: 759[Submit][St ...
- [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 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...
随机推荐
- Nginx调用远程php-fpm
在Nginx服务器的情况下,当我们输入 http://localhost:8080/index.php回车的时候 浏览器会将请求发送给Nginx,Nginx会根据我们所配置的以.php结尾的PHP的文 ...
- 配置Nginx代理服务器
nginx另一个使用的比较多的情况是作为代理服务器,代理服务器接收请求,然后把请求传递到代理服务器,nginx最后会提取代理服务器的回复,并把这些回复发送给客户端.我们将配置一个基本的代理服务器,图片 ...
- CodeForces 586D
题意略. 将人的移动分为3步,第一步向右,第二步是行之间的变换,第三步是向右走2步,三步加在一起算作是一次移动,计入判重数组. 在第一步时有一个特殊情况:已经越过最右边的边界线,这时graph[x][ ...
- Linux 安装nodejs环境以及路径配置
linux安装nodejs有2种方式一种简单的,解压即可用:另一种,通过下载source code ,通过编译,make,make install命令来安装. 这里只讲第一种,简单方便.不需要执行ma ...
- C#委托与事件--简单笔记
委托 简单记录点东西 适合似懂非懂的朋友看看 委托类型用来定义和响应应用程序中的回调. 借此可以设计各种有面向对象特性的代码模式.下面要说的事件在我看来就是委托的一种实现,再深一步讲,利用委托加事件, ...
- C语言队列(数组内核)
#include <stdio.h>#include <stdbool.h>#include <stdlib.h>struct Queue{ int *pBase; ...
- Spring IO Platform 解决Spring项目组合中版本依赖
简介: Spring IO Platform是Spring官网中排第一位的项目.它将Spring的核心API集成到一个适用于现代应用程序的平台中.提供了Spring项目组合中的版本依赖.这些依赖关系是 ...
- 自己编写的仿京东移动端的省市联动选择JQuery插件
概述 什么是插件,插件就是即插即用叫插件,很少的配置,很少的代码就可以用都项目里,之所以做这个插件,是因为做了一个省市区的联动,其他项目如果要用怎么办,难道在ctrl+c,ctrl+v?那样做太low ...
- C#的发展历程第五 - C# 7开始进入快速迭代道路
C# 7开始,C#加快了迭代速度,多方面的打磨让C#在易用性,效率等各方面都向完美靠近.另外得益于开源,社区对C#的进步也做了很大共享.下面带领大家看看C# 7的新特性.其中一部分是博主已经使用过,没 ...
- 【java学习笔记】线程
1.线程的定义 ①继承Thread类,将执行的任务逻辑放到run方法中,调用start方法来开启线程 public class ThreadDemo { public static void main ...