当前位置:网站首页>POJ3268最短路径题解
POJ3268最短路径题解
2022-07-28 12:37:00 【bj_hacker】
题目
链接
http://poj.org/problem?id=3268
字面描述
Silver Cow Party
Time Limit: 2000MS Memory Limit: 65536K
Total Submissions: 46808 Accepted: 20917
Description
One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1…N is going to attend the big cow party to be held at farm #X (1 ≤ X ≤ N). A total of M (1 ≤ M ≤ 100,000) unidirectional (one-way roads connects pairs of farms; road i requires Ti (1 ≤ Ti ≤ 100) units of time to traverse.
Each cow must walk to the party and, when the party is over, return to her farm. Each cow is lazy and thus picks an optimal route with the shortest time. A cow’s return route might be different from her original route to the party since roads are one-way.
Of all the cows, what is the longest amount of time a cow must spend walking to the party and back?
Input
Line 1: Three space-separated integers, respectively: N, M, and X
Lines 2…M+1: Line i+1 describes road i with three space-separated integers: Ai, Bi, and Ti. The described road runs from farm Ai to farm Bi, requiring Ti time units to traverse.
Output
Line 1: One integer: the maximum of time any one cow must walk.
Sample Input
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
Sample Output
10
Hint
Cow 4 proceeds directly to the party (3 units) and returns via farms 1 and 3 (7 units), for a total of 10 time units.
Source
USACO 2007 February Silver
思路
这道题有来回求,但并没有直接给出源点。
开始我们已x为源点,向其他点做最短路
接下来任意一点均要到x点做最短路
最后比较出两者之和的最大值
代码实现
#include<cstdio>
#include<string.h>
#include<cstring>
#include<queue>
using namespace std;
const int maxn=1e3+10;
const int maxm=1e5+10;
int n,m,x,cnt,ans;
int head[maxn],dis[maxn],dis1[maxn],dis2[maxn];
bool vis[maxn];
struct node{
int v,w,nxt;
}e[maxm];
inline bool add(int u,int v,int w){
e[++cnt].v=v;
e[cnt].w=w;
e[cnt].nxt=head[u];
head[u]=cnt;
}
inline void Dijkstra(int u){
queue<int>q;
memset(vis,false,sizeof(vis));
memset(dis,0x3f,sizeof(dis));
dis[u]=0;
vis[u]=true;
q.push(u);
while(!q.empty()){
int x=q.front();
q.pop();
vis[x]=false;
for(int i=head[x];i;i=e[i].nxt){
if(dis[e[i].v]>dis[x]+e[i].w){
dis[e[i].v]=dis[x]+e[i].w;
if(!vis[e[i].v]){
vis[e[i].v]=true;
q.push(e[i].v);
}
}
}
}
}
int main(){
scanf("%d%d%d",&n,&m,&x);
for(int i=1;i<=m;i++){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);
}
Dijkstra(x);
for(int i=1;i<=n;i++)dis1[i]=dis[i];
for(int i=1;i<=n;i++){
Dijkstra(i);
dis2[i]=dis[x];
ans=max(ans,dis1[i]+dis2[i]);
}
printf("%d\n",ans);
return 0;
}
边栏推荐
- LyScript 获取上一条与下一条指令
- Volcanic stone investment Zhang Suyang: hard technology, the relatively certain answer in the next 10 years
- Jar package
- [ecmascript6] function and its related use
- 严格模式——let和const——箭头函数——解构赋值——字符串模板symbol——Set和Map——生成器函数
- Blue Bridge Training (additional interview questions) day 7
- PHP生成随机数(昵称随机生成器)
- Auto.js enables Taobao to quickly submit orders
- POJ3275 Ranking the Cows题解
- Beyond istio OSS -- current situation and future of istio Service Grid
猜你喜欢

Children's programming electronic society graphical programming level examination scratch Level 2 real problem analysis (judgment question) June 2022

gicv3 spi register

二舅能治好年轻人的精神内耗吗?
![[dark horse morning post] byte valuation has shrunk to $270billion;](/img/58/8d5c78d919ed60bc833ec4daa22e23.jpg)
[dark horse morning post] byte valuation has shrunk to $270billion; "Second uncle" video author responded to plagiarism; Renzeping said that the abolition of the pre-sale system of commercial housing

不用Swagger,那我用啥?

Three men "running away" from high positions in the mobile phone factory

Strict mode -- let and const -- arrow function -- Deconstruction assignment -- string template symbol -- set and map -- generator function

Night God simulator packet capturing wechat applet

Jenkins--持续集成服务器

接口调不通,如何去排查?没想到10年测试老鸟栽在这道面试题上
随机推荐
Redis - Basics
少儿编程 电子学会图形化编程等级考试Scratch二级真题解析(判断题)2022年6月
面经整理,助力秋招,祝你称为offer收割机
docker部署mysql 实现远程连接[通俗易懂]
《如何打一场数据挖掘赛事》入门版
Basic exercises of DQL in MySQL
基于深度学习的超分辨率重建
屈辱、抗争、逆转,三十年,中国该赢微软一次了
Li Kou sword finger offer 51. reverse order pairs in the array
I miss the year of "losing" Li Ziqi
【ECMAScript6】Promise
【黑马早报】字节估值缩水,降至2700亿美元;“二舅”视频作者回应抄袭;任泽平称取消商品房预售制是大势所趋;美联储宣布再加息75个基点...
严格模式——let和const——箭头函数——解构赋值——字符串模板symbol——Set和Map——生成器函数
Night God simulator packet capturing wechat applet
How does the vditor renderer achieve server-side rendering (SSR)?
How to check if the interface cannot be adjusted? I didn't expect that the old bird of the 10-year test was planted on this interview question
火山石投资章苏阳:硬科技,下一个10年相对确定的答案
Three men "running away" from high positions in the mobile phone factory
Why is crypto game changing the game industry?
[C language] the difference between structure pointer and structure variable as formal parameters