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. Gradle系列之三 Gradle概述以及生命周期

    1 Gradle是一种编程框架 gradle主要由以下三部分组成 1 groovy核心语法 2 build script block 3 gradle api 注:本章所有的代码都在 https:// ...

  2. css margin边界叠加问题详谈

    问题:给子元素一个margin-top值,其父元素会跟着往下走margin-top的值 一.代码展示 HTML <body> <div class="box"&g ...

  3. hdoj1789【贪心】

    题意: 已知有n个作业,每个作业呢,都是一天可以做完,每个作业都有一个截止日期,每个作业如果超过他的截止日期会扣分,最后让你求一个怎么安排求得一个最小扣的分数. 比如现在有3个作业 截止日期:3 3 ...

  4. bzoj 2927: [Poi1999]多边形之战【博弈论】

    先手必胜状态是黑三角在边上 然后其他情况脑补一下,n为偶数先手必胜,可以理解为从某一边取,先手总有办法让后手取得一边有奇数个 #include<iostream> #include< ...

  5. windows虚拟机下 安装docker 踩过的坑

    首先,你的是win7.8还是win10 windows对docker兼容也是最近的事,所以win7.8的话,安装docker是要用工具箱的,不过官方给了下载. 国内话的可以通过,阿里镜像,或者清华镜像 ...

  6. jvm 实战

    https://blog.csdn.net/neutrojan/article/details/50532590# 1.ps -ef |grep java 找出最耗性能的JAVA进程2.top -Hp ...

  7. @ConfigurationProperties和@EnableConfigurationProperties配合使用

    https://blog.csdn.net/u010502101/article/details/78758330 @ConfigurationProperties注解主要用来把properties配 ...

  8. 将tomcat添加到系统服务

    一.安装服务 执行“service.bat install 二.卸载服务 在命令行中进入/Tomcat路径/bin/,执行“service.bat remove”  

  9. Linux修改文件的权限,拥有者,所属组

    修改文件的权限,拥有者,所属组 1.设置文件的权限(chmod) ①方式一(建议使用这种方式) 命名:chomd 755 文件名 ②方式二 命名:chomd -R +x 文件名 2.设置文件的拥有者( ...

  10. ios NSFileManager 用法详解

    转自:http://blog.csdn.net/ios_che/article/details/7287266 iPhone文件系统NSFileManager讲解是本文要介绍的内容,主要是通过ipho ...