https://www.luogu.org/problemnew/show/P2865

看到题解好多dijkstra,作为一名钟爱于spfa的蒟蒻看不下去了。

有些spfa要跑两边,代码量要曾长好多(虽然复制),而且还慢。

下面开始我的表演:

首先看清楚题意:题目说的是从n点往回走(因为双向边,所以好多人注意到也过了)

接着明确一个数组:

d[i][0]表示到i点的最短路

d[i][1]表示到i点的次短路

初始化数组,d[n][0]=0,d[n][1]=INF,其他的也都是INF;

然后将点进入队列开始,进行对其他点的更改。

记当前节点编号为u,目前所连边的编号为v。

我们将判断分为两块

(1)d[u][0]对于v点的影响。

(2)d[u][1]对于v点的影响。

#### (1)

如果$$d[u][0]+dis[u,v]<d[v][0]$$,也就是说足影响v点,那么此时的次短路变成了更新前的最短路,最短路更新。

如果
$$d[v][0]<=d[u][0]+dis[u,v]$$

$$d[v][0]>=d[u][0]+dis[u,v]$$

就是说不足以影响最短路,却可以影响次短路,能更新自然更新。

#### (2)

再开始判断d[u][1]对v点的影响

前边(1)部分先更新的最短路。

如果足矣更新最短路:那么到u点的最短路一定小于到u点的次短路,所以用d[u][0]一定更优。

如果没有更新:那么既然最短路都不能更新了,次短路还有啥用。

总的来说对v点最短路这一块理解就好,木有代码。

对于次短路我们要判断一下是否更新。

注意注意:以上判断都需要注意次短路严格小于最短路。

所以:

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#include <vector>
#include <stack>
#include <queue>
using namespace std;
struct ahah{
int nxt,to,dis;
}edge[];
int n,m;
int head[],tot;
void add(int x,int y,int z)
{
edge[++tot].nxt=head[x],edge[tot].to=y,edge[tot].dis=z,head[x]=tot;
}
int d[][];
bool vis[];
queue <int> que;
int read()
{
int sum=,fg=; char c=getchar();
while(c<''||c>''){if(c=='-')fg=-;c=getchar();}
while(c>=''&&c<=''){sum=sum*+c-'';c=getchar();}
return sum*fg;
}
void spfa(int s)
{
memset(d,0x7f,sizeof(d));
que.push(s);vis[s]=;
d[s][]=;
while(!que.empty())
{
int u=que.front();
vis[u]=;que.pop() ;
for(int i=head[u];i;i=edge[i].nxt)
{
int v=edge[i].to;
if(d[v][]>d[u][]+edge[i].dis)
{
d[v][]=d[v][];
d[v][]=d[u][]+edge[i].dis;
if(!vis[v])vis[v]=,que.push(v);
}
if(d[v][]>d[u][]+edge[i].dis&&d[u][]+edge[i].dis>d[v][])
{
d[v][]=d[u][]+edge[i].dis;
if(!vis[v])vis[v]=,que.push(v);
}
if(d[v][]>d[u][]+edge[i].dis)
{
d[v][]=d[u][]+edge[i].dis;
if(!vis[v])vis[v]=,que.push(v);
}
}
}
}
int main()
{
int x,y,z;
n=read();m=read();
for(int i=;i<=m;i++)
{
x=read(),y=read(),z=read();
add(x,y,z);add(y,x,z);
}
spfa(n);
printf("%d",d[][]);
}

luogu P2865 路障的更多相关文章

  1. P2865 [USACO06NOV]路障Roadblocks

    P2865 [USACO06NOV]路障Roadblocks 最短路(次短路) 直接在dijkstra中维护2个数组:d1(最短路),d2(次短路),然后跑一遍就行了. attention:数据有不同 ...

  2. 洛谷题解 P2865 【[USACO06NOV]路障Roadblocks】

    链接:https://www.luogu.org/problemnew/show/P2865 题目描述 Bessie has moved to a small farm and sometimes e ...

  3. 洛谷——P2865 [USACO06NOV]路障Roadblocks

    P2865 [USACO06NOV]路障Roadblocks 题目描述 Bessie has moved to a small farm and sometimes enjoys returning ...

  4. 络谷 P2865 [USACO06NOV]路障Roadblocks

    P2865 [USACO06NOV]路障Roadblocks 题目描述 Bessie has moved to a small farm and sometimes enjoys returning ...

  5. 洛谷P2865 [USACO06NOV]路障Roadblocks——次短路

    给一手链接 https://www.luogu.com.cn/problem/P2865 这道题其实就是在维护最短路的时候维护一下次短路就okay了 #include<cstdio> #i ...

  6. 「Luogu P3395」路障 解题报告

    点开有惊喜 其实是题面 这D1T1给的很有面子! 我居然做的来! 从左上角走到右上角 然后n<=1000 所以果断放弃DFS,选择BFS 思路还是一样的BFS 证明: 走到一个点的时间越早越好( ...

  7. P2865 【[USACO06NOV]路障Roadblocks】(次短路)

    传送门 算法Dijkstra要求次短路 那么在不考虑重复走一条边的情况下 肯定是把最短路中的一段改成另一段 至少要换另一条边到路径里所以可以枚举所有不属于最短路的每条边(a,b) 那么dis(1,a) ...

  8. 【洛谷 P2865】 [USACO06NOV]路障Roadblocks(最短路)

    题目链接 次短路模板题. 对每个点记录最短路和严格次短路,然后就是维护次值的方法了. 和这题一样. #include <cstdio> #include <queue> #in ...

  9. Luogu P2176 [USACO14FEB]路障Roadblock

    解题思路 这是一道最短路题目,不知道大家有没有做过玛丽卡这道题目,如果没做,在做完这道题之后可以去拿个双倍经验哦 先求出一张图中的最短路径,并将其记录下来,我们首先思考:要有增量的前提是新的最短路径比 ...

随机推荐

  1. bzoj 3625: [Codeforces Round #250]小朋友和二叉树【NTT+多项式开根求逆】

    参考:https://www.cnblogs.com/2016gdgzoi509/p/8999460.html 列出生成函数方程,g(x)是价值x的个数 \[ f(x)=g(x)*f^2(x)+1 \ ...

  2. JAVA实训总结:继承-——子类创建对象原理

    继承关键字:extends Java只允许单继承存在 不可以被继承的东西: 1.private成员 体现了java的封装特点,外部类只允许set()get()方法调用,若无set()方法,则类创建的对 ...

  3. 多线程 线程间通信 wait,notify

    1. 方法wait锁释放,notify()锁不释放

  4. sybase修改默认字符集为cp936

    原文地址:http://blog.sina.com.cn/s/blog_4d6854860100xn3f.html 报错信息:2402 error converting characters into ...

  5. django_models表设计

    和很多现代的web框架一样,django依赖于强大的数据访问层,试图将python面向对象特性和关系型数据库联系起来. 可移植性:不同的数据库,可以使用同一段代码,不用关心后台是哪家的数据库. 在一个 ...

  6. 关于 a 标签 jquery的trigger("click"),无法触发问题。

    这个问题的原因不是jquery的trigger("click"), 函数的问题, 而是 a标签之间要有其他子标签,要对这个子标签调用trigger("click" ...

  7. k-window的关闭与打开设置

    // 打开弹框窗口 public showKwinDow() { const that = this as any; // 设置窗口居中 that.$refs['setAddEdit'].widget ...

  8. 801硬件检测工具DragonHD的使用

    801硬件检测工具DragonHD的使用 2018/11/28 13:39 版本:V1.0 开发板:SC3817R 1.客户要认证器件,使用了全志官方的工具:DragonHD.exe 打开之后可以见用 ...

  9. HTTP协议 处理流程

    我们平时在浏览网页的时候都是使用浏览器,输入你要的网址后回车,就会显示出我们所想要的内容,看似这个简单的用户操作行为的背后,Web的工作原理是怎样的呢?到底隐藏了些什么呢? 对于传统的上网流程,系统它 ...

  10. 初识Vivado

    Vivado 设计套件包括高度集成的设计环境和新一代从系统到 IC 级的工具,这些均建立在共享的可扩展数据模型和通用调试环境基础上.这也是一个基于 AMBA AXI4 互联规范.IP-XACT IP ...