题目描述

原题来自:USACO 2007 Feb. Silver

N(1≤N≤1000)N (1 \le N \le 1000)N(1≤N≤1000) 头牛要去参加一场在编号为 x(1≤x≤N)x(1 \le x \le N)x(1≤x≤N) 的牛的农场举行的派对。有 M(1≤M≤100000)M(1\le M \le 100000)M(1≤M≤100000) 条有向道路,每条路长 Ti(1≤Ti≤100)T_i(1 \le T_i \le 100)T​i​​(1≤T​i​​≤100);每头牛都必须参加完派对后回到家,每头牛都会选择最短路径。求这 NNN 头牛的最短路径(一个来回)中最长的一条的长度。 特别提醒:可能有权值不同的重边。

输入格式

第 111 行:333 个空格分开的整数 N,M,XN,M,XN,M,X;

第 2…M+12 \ldots M+12…M+1 行:333 个空格分开的整数 Ai,Bi,TiA_i, B_i, T_iA​i​​,B​i​​,T​i​​,表示有一条从 AiA_iA​i​​ 到 BiB_iB​i​​ 的路,长度为 TiT_iT​i​​。

输出格式

一行一个数,表示最长最短路的长度。

样例

样例输入

4 8 2
1 2 4
1 3 2
1 4 7
2 1 1
2 3 5
3 1 2
3 4 4
4 2 3

样例输出

10

翻译题目,我们需要知道关于一个点,它到所有点的最短路以及所有点到它的最短路。
前者是最短路模板,后者是将所有边反着连,跑一边模板。
至于用Dijkstra还是SPFA,一看,没有负权边,向上看,我叫什么?
好了,用Dijkstra。
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstdlib>
#include <cstring>
#include <queue>
#define in(a) a=read()
#define REP(i,k,n) for(int i=k;i<=n;i++)
#define MAXN 100010
using namespace std;
inline int read(){
int x=,f=;
char ch=getchar();
for(;!isdigit(ch);ch=getchar())
if(ch=='-')
f=-;
for(;isdigit(ch);ch=getchar())
x=x*+ch-'';
return x*f;
}
int n,m,s,ans=-;
int total1,head1[MAXN],to1[MAXN],nxt1[MAXN],val1[MAXN];
int total2,head2[MAXN],to2[MAXN],nxt2[MAXN],val2[MAXN];
int dis1[MAXN],vis1[MAXN];
int dis2[MAXN],vis2[MAXN];
struct node{
int a,b;
};
priority_queue<node> Q;
bool operator < (node x,node y){
return x.b > y.b;
}
inline void adl1(int a,int b,int c){
total1++;
to1[total1]=b;
val1[total1]=c;
nxt1[total1]=head1[a];
head1[a]=total1;
return ;
}
inline void adl2(int a,int b,int c){
total2++;
to2[total2]=b;
val2[total2]=c;
nxt2[total2]=head2[a];
head2[a]=total2;
return ;
}
void dijkstra1(){
dis1[s]=;
Q.push(node{s,});
while(!Q.empty()){
int u=Q.top().a;
Q.pop();
if(vis1[u]) continue;
vis1[u]=;
for(int e=head1[u];e;e=nxt1[e])
if(dis1[to1[e]]>dis1[u]+val1[e]){
dis1[to1[e]]=dis1[u]+val1[e];
Q.push(node{to1[e],dis1[to1[e]]});
}
}
return ;
}
void dijkstra2(){
dis2[s]=;
Q.push(node{s,});
while(!Q.empty()){
int u=Q.top().a;
Q.pop();
if(vis2[u]) continue;
vis2[u]=;
for(int e=head2[u];e;e=nxt2[e])
if(dis2[to2[e]]>dis2[u]+val2[e]){
dis2[to2[e]]=dis2[u]+val2[e];
Q.push(node{to2[e],dis2[to2[e]]});
}
}
return ;
}
int main(){
in(n),in(m),in(s);
int a,b,c;
REP(i,,m) in(a),in(b),in(c),adl1(a,b,c),adl2(b,a,c);
REP(i,,n) dis1[i]=dis2[i]=;
dijkstra1();
dijkstra2();
REP(i,,n) ans=max(ans,dis1[i]+dis2[i]);
cout<<ans;
}
 

poj3268 Silver Cow Party(农场派对)的更多相关文章

  1. POJ3268 Silver Cow Party(dijkstra+矩阵转置)

    Silver Cow Party Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 15156   Accepted: 6843 ...

  2. POJ3268 Silver Cow Party —— 最短路

    题目链接:http://poj.org/problem?id=3268 Silver Cow Party Time Limit: 2000MS   Memory Limit: 65536K Total ...

  3. POJ3268 Silver Cow Party Dijkstra最短路

    Description One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to atten ...

  4. POJ-3268 Silver Cow Party---正向+反向Dijkstra

    题目链接: https://vjudge.net/problem/POJ-3268 题目大意: 有编号为1-N的牛,它们之间存在一些单向的路径.给定一头牛的编号X,其他牛要去拜访它并且拜访完之后要返回 ...

  5. poj3268 Silver Cow Party(两次dijkstra)

    https://vjudge.net/problem/POJ-3268 一开始floyd超时了.. 对正图定点求最短,对逆图定点求最短,得到任意点到定点的往返最短路. #include<iost ...

  6. POJ3268 Silver Cow Party【最短路】

    One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to attend the big co ...

  7. poj3268 Silver Cow Party(两次SPFA || 两次Dijkstra)

    题目链接 http://poj.org/problem?id=3268 题意 有向图中有n个结点,编号1~n,输入终点编号x,求其他结点到x结点来回最短路长度的最大值. 思路 最短路问题,有1000个 ...

  8. POJ3268 Silver Cow Party (建反图跑两遍Dij)

    One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to attend the big co ...

  9. POj3268 Silver Cow Party

    http://poj.org/problem?id=3268 题目大意:求到x距离与从x返回和的最大值 从x点到各个点最短路好求,直接用Dijkstar,但从各个点到x点却不好求,只要把路向翻转过来也 ...

随机推荐

  1. os._exit(), sys.exit(), exit()

    1. sys.exit(n) 退出程序引发SystemExit异常, 可以捕获异常执行些清理工作. n默认值为0, 表示正常退出. 其他都是非正常退出. 还可以sys.exit("sorry ...

  2. Linux Module框架【转】

    转自:http://www.cnblogs.com/LittleHann/p/4558719.html catalog 1. 概述 2. 使用模块 3. 插入和删除模块 4. 自动化与热插拔 5. 版 ...

  3. select()函数用法二

    Select在Socket编程中还是比较重要的,可是对于初学Socket的人来说都不太爱用Select写程序,他们只是习惯写诸如 connect.accept.recv或recvfrom这样的阻塞程序 ...

  4. 从Runoob的Django教程学到的

    Windows 10家庭中文版,Python 3.6.4,Django 2.0.3 这个月开始学习Django,从网上找到了RUNOOB.COM网站找到了一份Django教程,在“认真”学习之后,初步 ...

  5. python面向对象(六)之元类

    元类 1. 类也是对象 在大多数编程语言中,类就是一组用来描述如何生成一个对象的代码段.在Python中这一点仍然成立: In [13]: class ObjectCreator(object): . ...

  6. 正则表达式之你不知道的replace

    我们都知道js内置类String提供了一个replace方法,可以把指定字符串替换为另一个字符串,他的基础用法如下: var str="hello world"; var str= ...

  7. 使用qshell备份七牛云存储文件

    qshell是利用七牛文档上公开的API实现的一个方便开发者测试和使用七牛API服务的命令行工具.我们可以利用它来将七牛云上存储的文件备份到本地. 它提供Mac OSX, Linux, Windows ...

  8. (一)问候 Jsoup

    第一节: Jsoup 简介 Jsoup简介 jsoup 是一款Java 的HTML解析器,可直接解析某个URL地址.HTML文本内容.它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQu ...

  9. Python学习笔记:import sys模块(argv、path、platform、exit)

    sys模块是Python标准库中自带的一个模块. sys模块包括了一组非常实用的服务,内含很多函数方法和变量,用来处理Python运行时配置以及资源,从而可以与当前程序之外的系统环境交互,如:Pyth ...

  10. Jenkins 集成 Sonar

    Jenkins 与 Sonar 集成:Sonar 是 Jenkins 之外独立运行的一个服务.Jenkins 中安装插件 SonarQube(并配置其 Sonar Server 的 URL / Acc ...