题目链接

这道题纯属是一个裸的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 ;//程序拜拜
}

最新文章

  1. 为革命保护视力 --- 给 Visual Studio 换颜色
  2. iMac 重装系统
  3. FZU 2219 StarCraft(星际争霸)
  4. make_pair() (STL)
  5. php中遇到include_path=&#39;.;C:\php5\pear&#39;的错误
  6. Remastersys备份linux系统ISO镜像
  7. 射频识别技术漫谈(25)——Felica简介
  8. poj3308Paratroopers(最小割)
  9. Modular javascript(javascript模块化编程)
  10. 201521123096《Java程序设计》第十一周学习总结
  11. js函数之四大调用模式
  12. 【UOJ UNR #1】火车管理
  13. VUE2 项目 引入 leaflet.draw全过程
  14. 查看SQL实际内存占用
  15. web.xml的schema文件
  16. 搭建高可用mysql系列(1)-- Percona XtraDB Cluster介绍
  17. css - 三种方法解决LI和内部Img的上下间距问题
  18. 置换python2.7.13的opcode遇到的一些坑
  19. NB-IOT连接基站需要的步骤
  20. HDU6330-2018ACM暑假多校联合训练Problem L. Visual Cube

热门文章

  1. c语言相关知识点解析
  2. MongoDB在Windows下的环境配置和使用
  3. MYCAT实战之分片迁移
  4. Uboot详细解析2
  5. 基于C++11的线程池(threadpool),简洁且可以带任意多的参数
  6. selenium2 用Yaml文件进行元素管理 (五)
  7. Python学习笔记_操作Excel
  8. Java中迭代Map的方法
  9. win32多线程 (一) 线程创建与结束等待
  10. python 字符串,元组, 列表,字典之间的转换