题解 P1339 【[USACO09OCT]热浪Heat Wave】
2024-09-01 17:52:48
这道题纯属是一个裸的SPFA;
建议先把模板AC之后再做。
只需要做一些手脚,就是在加边的时候加一个双向边就好。
然后再第一次加点的时候
看不懂模板的出门左转度娘。
推荐下面一片讲解:
所以说,直接上代码。
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstdlib>
#include<queue>
using namespace std;
struct data{
int v;int next;
int value;
}edge[];//临界链表存变
int cnt;
int alist[];
void add(int u,int v,int value)
{
edge[++cnt].v=v;
edge[cnt].value=value;
edge[cnt].next=alist[u];
alist[u]=cnt;
return ;
}//加边
queue<int> q;
bool ins[];
int d[];
void spfa(int x)//跑一边SPFA,原理在上面
{
d[x]=;
q.push(x);
ins[x]=true;
while(!q.empty())
{
int now=q.front();
q.pop();ins[now]=false;
int next=alist[now];
while(next)
{
int v=edge[next].v;
int value=edge[next].value;
if(d[v]>d[now]+value)
{
d[v]=d[now]+value;
if(!ins[v])
{
q.push(v);
ins[v]=true;
}
}
next=edge[next].next;
}
}
return ;
}
int m,n,s,e;
int main()
{
scanf("%d%d%d%d",&m,&n,&s,&e);//输入
for(int i=;i<=n;i++)
{
int u,v,value;
scanf("%d%d%d",&u,&v,&value);
add(u,v,value);//加边
add(v,u,value);//反向边
}
for(int i=;i<=m;i++)
d[i]=0x3f3f3f3f;//初始化
spfa(s);//跑SPFA
printf("%d",d[e]);//输出
return ;//程序拜拜
}
最新文章
- 为革命保护视力 --- 给 Visual Studio 换颜色
- iMac 重装系统
- FZU 2219 StarCraft(星际争霸)
- make_pair() (STL)
- php中遇到include_path=&#39;.;C:\php5\pear&#39;的错误
- Remastersys备份linux系统ISO镜像
- 射频识别技术漫谈(25)——Felica简介
- poj3308Paratroopers(最小割)
- Modular javascript(javascript模块化编程)
- 201521123096《Java程序设计》第十一周学习总结
- js函数之四大调用模式
- 【UOJ UNR #1】火车管理
- VUE2 项目 引入 leaflet.draw全过程
- 查看SQL实际内存占用
- web.xml的schema文件
- 搭建高可用mysql系列(1)-- Percona XtraDB Cluster介绍
- css - 三种方法解决LI和内部Img的上下间距问题
- 置换python2.7.13的opcode遇到的一些坑
- NB-IOT连接基站需要的步骤
- HDU6330-2018ACM暑假多校联合训练Problem L. Visual Cube