说实话,这题真第一次见,学到了不少有趣的东西,因吹丝汀!!

思路:因为不可能同时并行和相遇(我也不知道为啥,等我会证明了就来说说)

所以正向建边再反向建边,拓扑排序+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----两个终点和两个起点,最短路最大交汇长度!!!的更多相关文章

  1. 「P4994」「洛谷11月月赛」 终于结束的起点(枚举

    题目背景 终于结束的起点终于写下句点终于我们告别终于我们又回到原点…… 一个个 OIer 的竞赛生涯总是从一场 NOIp 开始,大多也在一场 NOIp 中结束,好似一次次轮回在不断上演.如果这次 NO ...

  2. 2018.07.22 洛谷P3106 GPS的决斗Dueling GPS's(最短路)

    传送门 图论模拟题. 这题直接写3个(可以压成一个)spfa" role="presentation" style="position: relative;&q ...

  3. 洛谷 P2149 [SDOI2009]Elaxia的路线 解题报告

    P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w**的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia ...

  4. 洛谷P2149 Elaxia的路线

    传送门啦 分析: 我最开始想的是跑两遍最短路,然后记录一下最短路走了哪些边(如果有两条最短路就选经过边多的),打上标记.两边之后找两次都标记的边有多少就行了. 但...我并没有实现出来. 最后让我们看 ...

  5. 洛谷——P2149 [SDOI2009]Elaxia的路线

    P2149 [SDOI2009]Elaxia的路线 题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w每 ...

  6. 洛谷 P2149 [SDOI2009]Elaxia的路线

    题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间.Elaxia和w每天都要奔波于宿舍和实验室之间,他们 希望在节约时间的 ...

  7. 洛谷—— P2149 [SDOI2009]Elaxia的路线

    https://www.luogu.org/problem/show?pid=2149 题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两 ...

  8. 洛谷 P1529 回家 Bessie Come Home Label:Dijkstra最短路 && 乱搞

    题目描述 现在是晚餐时间,而母牛们在外面分散的牧场中. 农民约翰按响了电铃,所以她们开始向谷仓走去. 你的工作是要指出哪只母牛会最先到达谷仓(在给出的测试数据中,总会有且只有一只最快的母牛). 在挤奶 ...

  9. 洛谷 P5663 加工零件 & [NOIP2019普及组] (奇偶最短路)

    传送门 解题思路 很容易想到用最短路来解决这一道问题(题解法),因为两个点之间可以互相无限走,所以如果到某个点的最短路是x,那么x+2,x+4也一定能够达到. 但是如何保证这是正确的呢?比如说到某个点 ...

随机推荐

  1. linux环境变量设置和默认执行语句设置

    环境变量设置 1.export export ORACLE_HOME=/usr/local/instantclient_12_2export PATH=$ORACLE_HOME:$PATHexport ...

  2. 修改oracle编码格式

    文章参照:https://www.jb51.net/article/53078.htm 1.查看oracle当前编码格式: SELECT * FROM V$NLS_PARAMETERS WHERE P ...

  3. 自定义View系列教程05--示例分析

    站在源码的肩膀上全解Scroller工作机制 Android多分辨率适配框架(1)- 核心基础 Android多分辨率适配框架(2)- 原理剖析 Android多分辨率适配框架(3)- 使用指南 自定 ...

  4. jmter对于函数的处理

    1.获取当天的时间函数 ${__time(yyyy-MM-dd_HH-mm-ss)} 2.获取随机函数 ${__Random(100,300,)} 3.查看结果数

  5. es6 中let与const的简析

    1.let 它的作用类似于var,用来声明变量,但是所声明的变量,只在let命令所在的代码块内有效. if(true){ ; let b = ; } document.write(a); docume ...

  6. 5、nginx配置

    1.安装 sudo apt-get install nginx 2.启用 sudo service nginx start 3.若要将 Nginx 配置为转发请求向 ASP.NET Core 应用程序 ...

  7. dev stg prd 开发 测试 生产环境

    dev development 开发环境stg stage 测试环境prd product 线上环境

  8. 5分钟了解为什么学习Go

    1.什么是Go语言? Google开源 编译型语言 21世纪的C语言(主流编程语言都是单线程环境下发布的) 2.Go语言的特点? 简单易学习(类似python学习难度,自带格式化) 开发效率高 执行性 ...

  9. PPP验证对比

  10. 递归求gcd(a,b)

    int gcd(int a,int b) { ) return a; else return gcd(b,a%b); }