poj3268 Silver Cow Party(农场派对)
题目描述
原题来自: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)Ti(1≤Ti≤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_iAi,Bi,Ti,表示有一条从 AiA_iAi 到 BiB_iBi 的路,长度为 TiT_iTi。
输出格式
一行一个数,表示最长最短路的长度。
样例
样例输入
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(农场派对)的更多相关文章
- POJ3268 Silver Cow Party(dijkstra+矩阵转置)
Silver Cow Party Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 15156 Accepted: 6843 ...
- POJ3268 Silver Cow Party —— 最短路
题目链接:http://poj.org/problem?id=3268 Silver Cow Party Time Limit: 2000MS Memory Limit: 65536K Total ...
- POJ3268 Silver Cow Party Dijkstra最短路
Description One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to atten ...
- POJ-3268 Silver Cow Party---正向+反向Dijkstra
题目链接: https://vjudge.net/problem/POJ-3268 题目大意: 有编号为1-N的牛,它们之间存在一些单向的路径.给定一头牛的编号X,其他牛要去拜访它并且拜访完之后要返回 ...
- poj3268 Silver Cow Party(两次dijkstra)
https://vjudge.net/problem/POJ-3268 一开始floyd超时了.. 对正图定点求最短,对逆图定点求最短,得到任意点到定点的往返最短路. #include<iost ...
- 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 ...
- poj3268 Silver Cow Party(两次SPFA || 两次Dijkstra)
题目链接 http://poj.org/problem?id=3268 题意 有向图中有n个结点,编号1~n,输入终点编号x,求其他结点到x结点来回最短路长度的最大值. 思路 最短路问题,有1000个 ...
- 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 ...
- POj3268 Silver Cow Party
http://poj.org/problem?id=3268 题目大意:求到x距离与从x返回和的最大值 从x点到各个点最短路好求,直接用Dijkstar,但从各个点到x点却不好求,只要把路向翻转过来也 ...
随机推荐
- os._exit(), sys.exit(), exit()
1. sys.exit(n) 退出程序引发SystemExit异常, 可以捕获异常执行些清理工作. n默认值为0, 表示正常退出. 其他都是非正常退出. 还可以sys.exit("sorry ...
- Linux Module框架【转】
转自:http://www.cnblogs.com/LittleHann/p/4558719.html catalog 1. 概述 2. 使用模块 3. 插入和删除模块 4. 自动化与热插拔 5. 版 ...
- select()函数用法二
Select在Socket编程中还是比较重要的,可是对于初学Socket的人来说都不太爱用Select写程序,他们只是习惯写诸如 connect.accept.recv或recvfrom这样的阻塞程序 ...
- 从Runoob的Django教程学到的
Windows 10家庭中文版,Python 3.6.4,Django 2.0.3 这个月开始学习Django,从网上找到了RUNOOB.COM网站找到了一份Django教程,在“认真”学习之后,初步 ...
- python面向对象(六)之元类
元类 1. 类也是对象 在大多数编程语言中,类就是一组用来描述如何生成一个对象的代码段.在Python中这一点仍然成立: In [13]: class ObjectCreator(object): . ...
- 正则表达式之你不知道的replace
我们都知道js内置类String提供了一个replace方法,可以把指定字符串替换为另一个字符串,他的基础用法如下: var str="hello world"; var str= ...
- 使用qshell备份七牛云存储文件
qshell是利用七牛文档上公开的API实现的一个方便开发者测试和使用七牛API服务的命令行工具.我们可以利用它来将七牛云上存储的文件备份到本地. 它提供Mac OSX, Linux, Windows ...
- (一)问候 Jsoup
第一节: Jsoup 简介 Jsoup简介 jsoup 是一款Java 的HTML解析器,可直接解析某个URL地址.HTML文本内容.它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQu ...
- Python学习笔记:import sys模块(argv、path、platform、exit)
sys模块是Python标准库中自带的一个模块. sys模块包括了一组非常实用的服务,内含很多函数方法和变量,用来处理Python运行时配置以及资源,从而可以与当前程序之外的系统环境交互,如:Pyth ...
- Jenkins 集成 Sonar
Jenkins 与 Sonar 集成:Sonar 是 Jenkins 之外独立运行的一个服务.Jenkins 中安装插件 SonarQube(并配置其 Sonar Server 的 URL / Acc ...