洛谷p2149----两个终点和两个起点,最短路最大交汇长度!!!
说实话,这题真第一次见,学到了不少有趣的东西,因吹丝汀!!
思路:因为不可能同时并行和相遇(我也不知道为啥,等我会证明了就来说说)
所以正向建边再反向建边,拓扑排序+dp求最下长路,记录下最大的就是解

高中生的OI题好难呀
#include<iostream>
#include<vector>
#include<cstring>
#include<cstdio>
#include<queue>
#include<algorithm>
#include<map>
using namespace std;
#define maxn 2000
const int mod = 10000;
map<long long, int>ins;
struct Node {
int p;
int len;
Node(int a, int b) :p(a), len(b) {}
};
bool operator < (const Node a, const Node b) {
return a.len > b.len;
} vector<Node>G[maxn], G2[maxn];
int vis[maxn]; void insert(int be, int en, int len) {
G[be].push_back(Node(en, len));
}
int dijstra(int be, int *dis) {
for (int i = 1; i <= 1999; i++) dis[i] = 0x3f3f3f3f;
memset(vis, 0, sizeof(vis));
priority_queue<Node>que;
que.push(Node(be, 0));
dis[be] = 0;
while (!que.empty()) {
Node ans = que.top();
que.pop();
if (vis[ans.p] == 0) {
vis[ans.p] = 1;
for (int i = 0; i < G[ans.p].size(); i++) {
int p = G[ans.p][i].p;
if (dis[p] > dis[ans.p] + G[ans.p][i].len) {
dis[p] = dis[ans.p] + G[ans.p][i].len;
que.push(Node(p, dis[p]));
}
}
}
}
return 0;
}
int de[maxn];//度数
int n, m;
int ddd[maxn];
int topu() {
queue<int>que;
for (int i = 1; i <= n; i++) if (de[i] == 0) que.push(i);
while (!que.empty()) {
int x = que.front();
que.pop();
for (int i = 0; i < G2[x].size(); i++){
int p = G2[x][i].p;
ddd[p] = max(ddd[p], ddd[x] + G2[x][i].len);
de[p]--;
if (!de[p]) que.push(p);
}
}
return 0;
}
int dis1[maxn];
int dis2[maxn];
int dis3[maxn];
int dis4[maxn];
int main() { int be1, en1, be2, en2;
int len;
scanf("%d %d", &n, &m);
cin >> be1 >> en1 >> be2 >> en2;
int be, en;
for (int i = 0; i < m; i++) {
scanf("%d %d %d", &be, &en, &len);
insert(be, en, len);
insert(en, be, len);
}
dijstra(be1, dis1);
dijstra(en1, dis2);
dijstra(be2, dis3);
dijstra(en2, dis4);
int ans = -1;
for (int i = 1; i <= n; i++) {
for (int j = 0; j < G[i].size(); j++) {
int bee = i;
int enn = G[i][j].p;
int dt = G[i][j].len;
if (dis1[bee] + dis2[enn] + dt == dis1[en1]) {
if (dis3[bee] + dis4[enn] + dt == dis3[en2]) {//正向
G2[bee].push_back(Node(enn, dt));
de[enn]++;
}
}
}
}
topu();
memset(vis, 0, sizeof(vis));
for (int i = 1; i <= n; i++) {
ans = max(ddd[i], ans);
}
memset(ddd, 0, sizeof(ddd));
memset(de, 0, sizeof(de));
for (int i = 1; i <= n; i++) G2[i].clear(); for (int i = 1; i <= n; i++) {
for (int j = 0; j < G[i].size(); j++) {
int bee = i;
int enn = G[i][j].p;
int dt = G[i][j].len;
if (dis1[bee] + dis2[enn] + dt == dis1[en1]) {
if (dis3[enn] + dis4[bee] + dt == dis3[en2]) {//正向
G2[bee].push_back(Node(enn, dt));
de[enn]++;
}
}
}
}
topu();
for (int i = 1; i <= n; i++) {
ans = max(ddd[i], ans);
}
cout << ans << endl;
return 0;
}
洛谷p2149----两个终点和两个起点,最短路最大交汇长度!!!的更多相关文章
- 「P4994」「洛谷11月月赛」 终于结束的起点(枚举
题目背景 终于结束的起点终于写下句点终于我们告别终于我们又回到原点…… 一个个 OIer 的竞赛生涯总是从一场 NOIp 开始,大多也在一场 NOIp 中结束,好似一次次轮回在不断上演.如果这次 NO ...
- 2018.07.22 洛谷P3106 GPS的决斗Dueling GPS's(最短路)
传送门 图论模拟题. 这题直接写3个(可以压成一个)spfa" role="presentation" style="position: relative;&q ...
- 洛谷 P2149 [SDOI2009]Elaxia的路线 解题报告
P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia ...
- 洛谷P2149 Elaxia的路线
传送门啦 分析: 我最开始想的是跑两遍最短路,然后记录一下最短路走了哪些边(如果有两条最短路就选经过边多的),打上标记.两边之后找两次都标记的边有多少就行了. 但...我并没有实现出来. 最后让我们看 ...
- 洛谷——P2149 [SDOI2009]Elaxia的路线
P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w每 ...
- 洛谷 P2149 [SDOI2009]Elaxia的路线
题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w每天都要奔波于宿舍和实验室之间,他们 希望在节约时间的 ...
- 洛谷—— P2149 [SDOI2009]Elaxia的路线
https://www.luogu.org/problem/show?pid=2149 题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两 ...
- 洛谷 P1529 回家 Bessie Come Home Label:Dijkstra最短路 && 乱搞
题目描述 现在是晚餐时间,而母牛们在外面分散的牧场中. 农民约翰按响了电铃,所以她们开始向谷仓走去. 你的工作是要指出哪只母牛会最先到达谷仓(在给出的测试数据中,总会有且只有一只最快的母牛). 在挤奶 ...
- 洛谷 P5663 加工零件 & [NOIP2019普及组] (奇偶最短路)
传送门 解题思路 很容易想到用最短路来解决这一道问题(题解法),因为两个点之间可以互相无限走,所以如果到某个点的最短路是x,那么x+2,x+4也一定能够达到. 但是如何保证这是正确的呢?比如说到某个点 ...
随机推荐
- linux环境变量设置和默认执行语句设置
环境变量设置 1.export export ORACLE_HOME=/usr/local/instantclient_12_2export PATH=$ORACLE_HOME:$PATHexport ...
- 修改oracle编码格式
文章参照:https://www.jb51.net/article/53078.htm 1.查看oracle当前编码格式: SELECT * FROM V$NLS_PARAMETERS WHERE P ...
- 自定义View系列教程05--示例分析
站在源码的肩膀上全解Scroller工作机制 Android多分辨率适配框架(1)- 核心基础 Android多分辨率适配框架(2)- 原理剖析 Android多分辨率适配框架(3)- 使用指南 自定 ...
- jmter对于函数的处理
1.获取当天的时间函数 ${__time(yyyy-MM-dd_HH-mm-ss)} 2.获取随机函数 ${__Random(100,300,)} 3.查看结果数
- es6 中let与const的简析
1.let 它的作用类似于var,用来声明变量,但是所声明的变量,只在let命令所在的代码块内有效. if(true){ ; let b = ; } document.write(a); docume ...
- 5、nginx配置
1.安装 sudo apt-get install nginx 2.启用 sudo service nginx start 3.若要将 Nginx 配置为转发请求向 ASP.NET Core 应用程序 ...
- dev stg prd 开发 测试 生产环境
dev development 开发环境stg stage 测试环境prd product 线上环境
- 5分钟了解为什么学习Go
1.什么是Go语言? Google开源 编译型语言 21世纪的C语言(主流编程语言都是单线程环境下发布的) 2.Go语言的特点? 简单易学习(类似python学习难度,自带格式化) 开发效率高 执行性 ...
- PPP验证对比
- 递归求gcd(a,b)
int gcd(int a,int b) { ) return a; else return gcd(b,a%b); }