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

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

所以正向建边再反向建边,拓扑排序+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. PHP判断图片格式的七种方法小结

    <?php $imgurl = "http://www.jb51.net/images/logo.gif"; //方法1 echo $ext = strrchr($imgur ...

  2. UVa-10986_Sending email (向前星+Dijkstra)

    题意:给你点.边,求起点到终点的最短距离. 题解:由于题目的数据量特别大,所以需要用邻接表来存边,之后对Dijkstra算法稍微魔改一下就可以了,本来以为会超时,做好了打堆优化的准备,结果卡时间过了, ...

  3. 12-2 js基础

    一 数据类型 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  4. HZOJ 礼物

    其实是比较简单的一道期望状压dp,考试时一直在想数组表示概率,然而最后出的数总是小于一,于是无奈的把第一个点判掉放弃了其他点. 设f[i]为状态为i时到全部买到的期望次数,$f[i]=∑f[j]*p[ ...

  5. Android教程-03 常见布局的总结

    常见的布局 视频建议采用超清模式观看, 欢迎点击订阅我的优酷 Android的图形用户界面是由多个View和ViewGroup构建出来的.View是通用的UI窗体小组件,比如按钮(Button)或者文 ...

  6. oracle用NOT EXISTS替代NOT IN

    在子查询中,NOT IN子句将执行一个内部的排序和合并. 无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执行了一个全表遍历).  为了避免使用NOT IN ,我们可以把它改写成外连 ...

  7. css3鼠标移动图片上移效果

    css3的功能真是很强大,学无止境,不多说,直接上代码 css部分: <style> ;;} .text-center{text-align:center} .col_cont{width ...

  8. [转]FileDescriptor详解

    FileDescriptor是"文件描述符". FileDescriptor可以被用来表示开放的文件,开放的套接字等. 当FileDescriptor表示文件来说,当FIleDes ...

  9. Example-09-01

    #define _CRT_SECURE_NO_WARNINGS #include <cstdio> #include <cstring> int min(int a, int ...

  10. 三分钟学会@Autowired@Qualifier@Primary注解

    三分钟学会@Autowired@Qualifier@Primary注解 2018.10.08 20:24 154浏览 今天主要简单的跟大家介绍一下spring自动装配相关的@Autowired,@Qu ...