【BZOJ 3232】圈地游戏 二分+SPFA判环/最小割经典模型
最小割经典模型指的是“一堆元素进行选取,对于某个元素的取舍有代价或价值,对于某些对元素,选取后会有额外代价或价值”的经典最小割模型,建立倒三角进行最小割。
这个二分是显然的,一开始我也是想到了最小割的那个模型的但是我觉得他会不是一个圈我就否掉了,但是仔细想想的话会发现,如果是这样的话所得到的答案一定小于等于一个圈的答案(浓度),所以我们可定会得到最终答案,所以这样做是可以的,所以说要有宽松得正解的意识(泥沙俱下但沙子不影响我泥)。当时我否掉最小割以后就立马去想费用流了,然后想到建图后发现那样建图虽然不好跑费用流,但是SPFA判环还是很劲的,所以我就判了一发环。
在这里就顺便说一下SPFA判负(正)环吧。DFS的话就是判断一个点是否重复出现在DFS路径中,他有一个优化(没看呢),就叫他DFS+吧。然后他还有BFS版的,就是判断一个点是否重复入队n次(点数),但是不能判断是否被更新n次,这样有可能会出错(不用重边就可以做到)(也许可以分析是否可行但是不会很简单而且很难考虑周全),并且这两种方法的时间复杂度有些时候差距并不大只不过是一个常数。网上还有人说是进队次数大于入度,这个经试验证明是扯淡。还有另一种做法是判断到达次点的最短路径的边数等于n这个不仅很对还很快,就叫他BFS+吧。
对于这道题DFS会T,然而DFS+,BFS,以及BFS+均可过,而BFS+表现最优。这说明虽然找最短路方面BFS_SPFA找最短路比DFS_SPFA要好,但是在判环方面并不是DFS一定优于BFS,比如这道题,所以说BFS大法吼。
#include <cstdio>
#include <cstring>
#include <algorithm>
#define pos(a,b) (((a)-1)*(m+1)+(b))
typedef long double db;
const int N=;
const int P=N*N;
const int E=P*;
const db oo=-1e18;
const db eps=1e-;
const db ans_eps=1e-;
struct V{
int to,next;
db w;
}c[E];
int head[P],t;
inline void add(int x,int y,db z){
c[++t].to=y,c[t].next=head[x],head[x]=t,c[t].w=z;
}
db dis[P];
bool in[P];
int n,m,sum;
int val[N][N],cost1[N][N],cost2[N][N];
int q[P],front,back;
int cnt[P];
inline bool spfa(int s){
q[back++]=s,in[s]=true;
if(back==P)back=;
while(front!=back){
int x=q[front++];
in[x]=false;
if(front==P)front=;
for(int i=head[x];i;i=c[i].next)
if(dis[x]+c[i].w-dis[c[i].to]>eps){
dis[c[i].to]=dis[x]+c[i].w;
cnt[c[i].to]=cnt[x]+;
if(cnt[c[i].to]==sum)return true;
if(in[c[i].to]==false){
q[back++]=c[i].to;
in[c[i].to]=true;
if(back==P)back=;
}
}
}
return false;
}
inline bool check(db mid){
memset(head,,sizeof(head)),t=;
memset(in,,sizeof(in));
memset(cnt,,sizeof(cnt));
for(int i=;i<=sum;++i)dis[i]=oo;
for(int i=;i<=n+;++i)
for(int j=;j<=m+;++j){
if(j!=m+)
add(pos(i,j),pos(i,j+),-cost1[i][j]*mid+val[i][j]);
if(j!=)
add(pos(i,j),pos(i,j-),-cost1[i][j-]*mid-val[i][j-]);
if(i!=n+)
add(pos(i,j),pos(i+,j),-cost2[i][j]*mid);
if(i!=)
add(pos(i,j),pos(i-,j),-cost2[i-][j]*mid);
}
dis[sum/]=.;
return spfa(sum/);
}
int main(){
scanf("%d%d",&n,&m);
sum=(n+)*(m+);
for(int i=;i<=n;++i)
for(int j=;j<=m;++j)
scanf("%d",&val[i][j]);
for(int i=;i<=m;++i)
for(int j=n;j>;--j)
val[j][i]+=val[j+][i];
for(int i=;i<=n+;++i)
for(int j=;j<=m;++j)
scanf("%d",&cost1[i][j]);
for(int i=;i<=n;++i)
for(int j=;j<=m+;++j)
scanf("%d",&cost2[i][j]);
db l=.,r=.,mid,ans=.;
while(l+ans_eps<r){
mid=(l+r)*0.5;
if(check(mid))
ans=mid,l=mid;
else
r=mid;
}
printf("%.3f",(double)ans);
return ;
}
【BZOJ 3232】圈地游戏 二分+SPFA判环/最小割经典模型的更多相关文章
- BZOJ 3232: 圈地游戏 分数规划+判负环
3232: 圈地游戏 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 966 Solved: 466[Submit][Status][Discuss] ...
- bzoj 3232: 圈地游戏
bzoj 3232: 圈地游戏 01分数规划,就是你要最大化\(\frac{\sum A}{\sum B}\),就二分这个值,\(\frac{\sum A}{\sum B} \geq mid\) \( ...
- bzoj 3232 圈地游戏——0/1分数规划(或网络流)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232 当然是0/1分数规划.但加的东西和减的东西不在一起,怎么办? 考虑把它们合在一起.因为 ...
- bzoj 3232 圈地游戏 —— 01分数规划+最小割建图(最大权闭合子图)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232 心烦意乱的时候调这道题真是...越调越气,就这样过了一晚上... 今天再认真看看,找出 ...
- bzoj 3232: 圈地游戏【分数规划+最小割】
数组开小导致TTTTTLE-- 是分数规划,设sm为所有格子价值和,二分出mid之后,用最小割来判断,也就是判断sm-dinic()>=0 这个最小割比较像最大权闭合子图,建图是s像所有点连流量 ...
- bzoj 3232: 圈地游戏 01分数规划
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3232 题解: 首先我们看到这道题让我们最优化一个分式. 所以我们应该自然而然地想到01分 ...
- bzoj 2132 圈地计划(黑白染色,最小割)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2132 [题意] 给定n*m个区域,建工业区价值A,建商业区价值B,如果(i,j)有k个 ...
- poj 2049(二分+spfa判负环)
poj 2049(二分+spfa判负环) 给你一堆字符串,若字符串x的后两个字符和y的前两个字符相连,那么x可向y连边.问字符串环的平均最小值是多少.1 ≤ n ≤ 100000,有多组数据. 首先根 ...
- 2018.09.12 poj3621Sightseeing Cows(01分数规划+spfa判环)
传送门 01分数规划板题啊. 发现就是一个最优比率环. 这个直接二分+spfa判负环就行了. 代码: #include<iostream> #include<cstdio> # ...
随机推荐
- 源码安装CentOs7下的PHP7
首先安装APACHE环境,直接用yum安装 yum install httpd httpd-devel /etc/httpd/ systemctl start httpd.service #启动apa ...
- CAS解扰小结
1.每个ts数据包由:1.包头 2.包数据 包头有个字段 PID ,该字段指示包数据的类型.比如说: PID 为 0x0000 包数据的类型就是 PAT表 PID 为 0x0001 包数据的类型就是 ...
- 006---Python基本数据类型--集合
集合 .caret, .dropup > .btn > .caret { border-top-color: #000 !important; } .label { border: 1px ...
- xpath简单入门
语法: 选取节点: 实例: (贴图转载自w3school) 补充: /a/@href #获取a标签的href属性 当<div class="demo">& ...
- android .9图制作
andorid .9 图,可用于适配各种屏幕.制作的时候,很简单. 在stadio 里面,把鼠标放到图片的边界,点一下.这时候,图片的边缘会有黑块. 然后把鼠标放到黑块上,发现可以拉伸区域了. 这个区 ...
- 读取hbase数据到mysql
先写一个自己的MyRecordWriter类 extends RecordWriter package calllog; import java.io.IOException; import java ...
- spring、spring-data-redis整合使用
一.Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 从2010年3月15日起,Redis的开发工作由VMwa ...
- web开发微信文章目录
Web开发微信文章目录 2015-12-13 Web开发 本文是Web开发微信的文章目录.通过目录查看文章编号,回复文章编号就能查看文章全文. 回复编号查看全文,搜索分类名可以获得该分类下的文章. ...
- 再见NullPointerException。在Kotlin里null的处理(KAD 19)
作者:Antonio Leiva 时间:Apr 4, 2017 原文链接:https://antonioleiva.com/nullity-kotlin/ 关于Kotlin最重要的部分之一:无效处理, ...
- Visual Studio 2015安装包
点击下载