SPFA小总结
关于spfa
知识点
原始版 ---裸
应用:
一、判负环
两种方法
1.跑单源点bfs,如果某一个点入队了n-1次,存在
2.对于每个点dfs,如果此源点反被其他点更新,存在
证明:点i作为源点,d[i]==0 若i被更新,d[i]<0 定存在负环
优化:若初始d[]={0} 则最开始一定先跑权为负的边,更容易找到负环
int d[N]={0};fg=1;
for(int i=1;i<=n;i++){dfs(i);if(!fg)break;}
void dfs(int u){
if(!fg)return;
vis[u]=1;
for(int i=hd[u];i;i=e[i].next){
int v=e[i].v;
if(d[v]>d[u]+e[i].w){
if(vis[v]){fg=0;return;}
d[v]=d[u]+e[i].w;
dfs(v);
}
}
vis[u]=0;
}
二、网络流最小费用最大流
无限spfa直到没有可流的量
在原始spfa中,加入流量限制 ,记录入边
每次spfa结束后沿入边更新流量即可
queue<int>q;
bool spfa(int s,int t,int &flow,int &cost){
for(int i=1;i<=t;i++)d[i]=inf;
memset(vis,0,sizeof(vis));
memset(pre,-1,sizeof(pre));
q.push(s);vis[s]=1;a[s]=inf;
while(!q.empty()){
int u=q.front();q.pop();
vis[u]=0;
for(int i=head[u];i!=-1;i=e[i].next){
int v=e[i].v;
if(e[i].cap>e[i].flow&&d[v]>d[u]+e[i].w){
d[v]=d[u]+e[i].w;
pre[v]=i;
a[v]=min(e[i].cap-e[i].flow,a[u]);
if(!vis[v]){
q.push(v);
vis[v]=1;
} }
}
}
if(d[t]==inf)return 0;
flow+=a[t];cost+=d[t]*a[t];
int u=t;
while(u!=s){
e[pre[u]].flow+=a[t];
e[pre[u]^1].flow-=a[t];
u=e[pre[u]].u;
}
return 1;
}
int flow=0,cost=0;
while(spfa(0,n+1,flow,cost));
三、差分约束
建图更复杂,建好图就很水了
优化:
SLF
双向队列优化 若d[v]<d[head] 插入队首 否则队尾
堆优化:手写小顶堆或者STL优先队列
优点
跑稀疏图较快且可以跑负边权
复杂度 O(E*K) K为常数且大致为1~2
题目分析:
Spfa其实很简单啊,只是建模比较麻烦了
1.首先今上午的考试题,spfa中加一个dp,存到现在点用了几个血包,但由于恶心的出题人卡了你一下,你需要一个SLF优化或者转成dijkstra
知识点:dp+优化
2.某个题目吧,大致是一个n*m的方格图,只能沿着边走,问从一个坐标到另一个坐标最少需要转几次弯。 拆点,每个格点拆为上下左右四个点,表示向哪个方向走,想到拆点之后建边就很简单了
知识点:拆点
3.一道很裸的判负环的题,方法上面又讲,代码也很简单
知识点:判负环
4.分层spfa,有一些层次,每个层次只能向下一层次建边
知识点:建模
大概见过的题目好像就只有这些了。。。
考得多的其实是拆点和建边吧
(完)
SPFA小总结的更多相关文章
- SPFA 小优化*2
/* bzoj 2763 SPFA小优化 循环队列+SLF 顺面改掉自己之前手打qeueu的坏毛病*/ #include<iostream> #include<cstring> ...
- 小K的农场(差分约束,spfa)
题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b至少多种植了c个单位的作 ...
- 【最短路】【spfa】小vijos P1447 Updown
小vijos P1447 Updown 背景 开启了升降梯的动力之后,探险队员们进入了升降梯运行的那条竖直的隧道,映入眼帘的是一条直通塔顶的轨道.一辆停在轨道底部的电梯.和电梯内一杆控制电梯升降的巨大 ...
- 2018年长沙理工大学第十三届程序设计竞赛 E小木乃伊到我家(spfa模版)
链接:https://www.nowcoder.com/acm/contest/96/E来源:牛客网 小木乃伊到我家 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他 ...
- 【bzoj3436】小K的农场 差分约束系统+最长路-Spfa
原文地址:http://www.cnblogs.com/GXZlegend/p/6801470.html 题目描述 背景 小K是个特么喜欢玩MC的孩纸... 描述 小K在MC里面建立很多很多的农场,总 ...
- Spfa【P1813】拯救小tim_NOI导刊2011提高(02)
Description 小tim在游乐场,有一天终于逃了出来!但是不小心又被游乐场的工作人员发现了„„所以你的任务是安全地把小tim护送回家.但是,A市复杂的交通状况给你出了一大难题. A市一共有n个 ...
- SPFA的小优化
标签:闲扯 SPFA的小优化 1. 向队尾加入元素时,如果它比对首还优,就把把它直接和队首交换. 拿一个双端队列来实现 (手写 , head ,tail STLdeque亲测及其慢) 这个小优化其 ...
- HihoCoder - 1093 小Hi和小Ho (SPFA)
描述 万圣节的晚上,小Hi和小Ho在吃过晚饭之后,来到了一个巨大的鬼屋! 鬼屋中一共有N个地点,分别编号为1..N,这N个地点之间互相有一些道路连通,两个地点之间可能有多条道路连通,但是并不存在一条两 ...
- 几个小模板:topology, dijkstra, spfa, floyd, kruskal, prim
1.topology: #include <fstream> #include <iostream> #include <algorithm> #include & ...
随机推荐
- 搭建java环境——使用Sublime Text 3(windows环境)
实现sublime Text 3对Java编译执行 参考网址:http://tieba.baidu.com/p/2609515186 1.1直接在安装路径下找到*\Packages\Java.subl ...
- [Cerc2013]Magical GCD
https://vjudge.net/problem/UVA-1642 题意:在一个序列中,找出一段连续的序列,使得长度*gcd最大 固定右端点,当左端点从左向右移动时,gcd不变或变大 gcd相同时 ...
- es6+react.js组件入门初探
React是一个用于构建用户见面的javascript库. React主要用于构建UI,许多人认为React是MVC中的V(视图) React起源于Facebook的内部项目,用来架设Instagra ...
- css3动画 一行字鼠标触发 hover 从左到右颜色渐变
偶然的机会发现的这个东东 这几天做公司的官网 老板突然说出了一个外国网站 我就顺手搜了 并没有发现他说的高科技 但是一个东西深深地吸引了我 就是我下面要说的动画 这个好像不能放视频 我就简单的描述一 ...
- CSS <input type="file">样式设置
这是最终想要的效果~~~ 实现很简单,div设置背景图片,<input type="file"/>绝对定位上去再设置opacity:0(透明度为0 ) 直接上代码,希望 ...
- Python之旅.第三章.函数3.27
一.形参与实参 1.形参与实参是什么? 形参(形式参数):指的是 在定义函数时,括号内定义的参数,形参其实就变量名 实参(实际参数),指的是 在调用函数时,括号内传入的值,实参其实就变量的值 x,y是 ...
- BizTalk Server 2016配置 WCF SAP Adapter
BizTalk Server 2016配置 WCF SAP Adapter 最近公司内部需要使用BizTalk与SAP 系统进行对接,虽然SAP/PI可以以发布WebService 的方式实现与外部系 ...
- C# 后台构造json数据
前后台传值一般情况下,都会用到json类型的数据,比较常见,但是每次用到的时候去网上找比较麻烦,所以自己记录一下,下次直接用. 构造的json串格式,如下: [{","name&q ...
- GridControl的常用操作
1.GridView的回车跳转单元格和换行 private void gridView1_KeyPress(object sender, KeyPressEventArgs e) { ...
- python基础——面向对象进阶下
python基础--面向对象进阶下 1 __setitem__,__getitem,__delitem__ 把对象操作属性模拟成字典的格式 想对比__getattr__(), __setattr__( ...