洛谷 P1339 [USACO09OCT]热浪Heat Wave
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了洛谷 P1339 [USACO09OCT]热浪Heat Wave相关的知识,希望对你有一定的参考价值。
题目链接:https://www.luogu.org/problem/show?pid=1339
题目描述
德克萨斯纯朴的民众们这个夏天正在遭受巨大的热浪!!!他们的德克萨斯长角牛吃起来不错,可是他们并不是很擅长生產富含奶油的乳製品。Farmer John此时以先天下之忧而忧,后天下之乐而乐的精神,身先士卒地承担起向德克萨斯运送大量的营养冰凉的牛奶的重任,以减轻德克萨斯人忍受酷暑的痛苦。
FJ已经研究过可以把牛奶从威斯康星运送到德克萨斯州的路线。这些路线包括起始点和终点先一共经过T (1 <= T <= 2,500)个城镇,方便地标号為1到T。除了起点和终点外地每个城镇由两条双向道路连向至少两个其它地城镇。每条道路有一个通过费用(包括油费,过路费等等)。
给定一个地图,包含C (1 <= C <= 6,200)条直接连接2个城镇的道路。每条道路由道路的起点Rs,终点Re (1 <= Rs <= T; 1 <= Re <= T),和花费(1 <= Ci <= 1,000)组成。求从起始的城镇Ts (1 <= Ts <= T)到终点的城镇Te(1 <= Te <= T)最小的总费用。
输入输出格式
输入格式:
第一行: 4个由空格隔开的整数: T, C, Ts, Te
第2到第C+1行: 第i+1行描述第i条道路。有3个由空格隔开的整数: Rs, Re和Ci
输出格式:
一个单独的整数表示从Ts到Te的最小总费用。数据保证至少存在一条道路。
输入输出样例
7 11 5 4 2 4 2 1 4 3 7 2 2 3 4 3 5 7 5 7 3 3 6 1 1 6 3 4 2 4 3 5 6 3 7 2 1
7
说明
【样例说明】
5->6->1->4 (3 + 1 + 3)
吐槽:天热了吃雪糕不好么qwq非要喝冰凉凉牛奶
谁说雪糕不能用牛奶做了……
FJ:What‘s up???
分析:
最短路模板。这里选择SPFA(因为写得最顺)。
个人感觉图论很多知识是不需要理解透彻了再去写代码的。把代码多抄两遍,慢慢就会懂得原理。
上代码:
1 #include<iostream> 2 #include<cstdio> 3 #include<cmath> 4 #include<algorithm> 5 #include<cstring> 6 #include<queue> 7 8 using namespace std; 9 const int MAXN = 10000 + 5; 10 11 int f,t,v,s,e,n,m; 12 int tot; 13 int first[MAXN],nxt[MAXN << 1],dis[MAXN]; 14 bool use[MAXN]; 15 16 struct edge 17 { 18 int f,t,v; 19 }l[MAXN << 1]; 20 21 void init() 22 { 23 memset(first,-1,sizeof(first)); 24 tot = 0; 25 } 26 27 void build(int f,int t,int v) 28 { 29 l[++ tot] = (edge){f,t,v}; 30 nxt[tot] = first[f]; 31 first[f] = tot; 32 } 33 34 queue <int> q; 35 36 void spfa(int s) 37 { 38 memset(dis,0x3f,sizeof(dis)); 39 while(!q.empty()) 40 q.pop(); 41 q.push(s); 42 use[s] = 1; 43 dis[s] = 0; 44 45 while(!q.empty()) 46 { 47 int u = q.front(); 48 q.pop(); 49 use[u] = 0; 50 51 for(int i = first[u];i != -1;i = nxt[i]) 52 { 53 int v = l[i].t; 54 if(dis[v] > dis[u] + l[i].v) 55 { 56 dis[v] = dis[u] + l[i].v; 57 if(!use[v]) 58 { 59 use[v] = 1; 60 q.push(v); 61 } 62 } 63 } 64 } 65 } 66 int main() 67 { 68 scanf("%d%d%d%d",&n,&m,&s,&e); 69 init(); 70 for(int i = 1;i <= m;i ++) 71 { 72 scanf("%d%d%d",&f,&t,&v); 73 build(f,t,v); 74 build(t,f,v); 75 } 76 spfa(s); 77 printf("%d",dis[e]); 78 return 0; 79 }
注意:
1.由于是无向图,所以建图时要build两次。
2.洛谷评测机使用Linux系统,time、next都是Linux的关键字,变量名要格外注意。当然如果你用CodeVS等使用Windows系统评测机的OJ就不用担心这个问题。
以上是关于洛谷 P1339 [USACO09OCT]热浪Heat Wave的主要内容,如果未能解决你的问题,请参考以下文章
洛谷 P1339 [USACO09OCT]热浪Heat Wave