题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232

心烦意乱的时候调这道题真是...越调越气,就这样过了一晚上...

今天再认真看看,找出几处小错,就A了...

关于题解:https://www.cnblogs.com/CQzhangyu/p/6790404.html

关于最大权闭合子图:http://www.cnblogs.com/wuyiqi/archive/2012/03/12/2391960.html

对于这道题,首先,可以01分数规划,于是问题变成二分比值后找最大答案;

把每个格子看做一个点,点之间的边权是格子边上的值*二分的比值,则割掉这条边表示两个点中选一个,那么自然一内一外,它们的交界也就成了封闭路线的边界;

把外围看做还有一圈点,于是边缘的点向汇点连外围边界的值的边;

然后源点向每个点连权值为点(格子)权的边,割这条边表示不要这个点的贡献了;

在这个图上跑最小割,总点权减去最小割就是答案;

注意 ct = 1 !边权要乘二分的比值 k !

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define eps 1e-6
#define inf 1e9
using namespace std;
int const xn=,xm=,xe=5e4;//
int n,m,s,t,w[xn][xn],sid[xn][xn][xn][xn],S,T;
int dis[xm],hd[xm],ct=,to[xe],nxt[xe],cur[xm];
int e1[xn][xn],e2[xn][xn];
double ans,c[xe],sum;
queue<int>q;
void add(int x,int y,double z)
{
to[++ct]=y; nxt[ct]=hd[x]; c[ct]=z; hd[x]=ct;
to[++ct]=x; nxt[ct]=hd[y]; c[ct]=; hd[y]=ct;
}
int rd()
{
int ret=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=; ch=getchar();}
while(ch>=''&&ch<='')ret=(ret<<)+(ret<<)+ch-'',ch=getchar();
return f?ret:-ret;
}
int id(int x,int y){return (x-)*m+y;}
int P(int x,int y){return (x-)*m+y;} bool bfs()
{
while(q.size())q.pop();
memset(dis,,sizeof dis);
dis[s]=; q.push(s);
while(q.size())
{
int x=q.front(); q.pop();
for(int i=hd[x],u;i;i=nxt[i])
if(!dis[u=to[i]]&&c[i]>eps)dis[u]=dis[x]+,q.push(u);
}
return dis[t];
}
double dfs(int x,double fl)
{
if(x==t)return fl;
double ret=;
for(int &i=cur[x],u;i;i=nxt[i])
{
if(dis[u=to[i]]!=dis[x]+||c[i]<=eps)continue;
double tmp=dfs(u,min(fl-ret,c[i]));
if(tmp<eps)dis[u]=;
c[i]-=tmp; c[i^]+=tmp;
ret+=tmp; if(fl-ret<eps)return ret;
}
return ret;
}
bool ck(double k)
{
memset(hd,,sizeof hd); ct=;//=1 而不是 0 !!!!!!!!!!!!!!!!!!!!!!!
s=; t=n*m+;
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
{
int x=id(i,j);
add(s,x,w[i][j]);
if(i==)add(x,t,sid[i-][j][i][j]*k);
if(j==)add(x,t,sid[i][j-][i][j]*k);
if(i==n)add(x,t,sid[i][j][i+][j]*k);
if(j==m)add(x,t,sid[i][j][i][j+]*k);
int y=id(i+,j),z=id(i,j+);
if(i<n)add(x,y,k*sid[i][j][i+][j]),add(y,x,k*sid[i][j][i+][j]);
if(j<m)add(x,z,k*sid[i][j][i][j+]),add(z,x,k*sid[i][j][i][j+]);//k*!!!
}
double ans=;
while(bfs())
{
memcpy(cur,hd,sizeof hd);
ans+=dfs(,inf);
}
return sum-ans>eps;
}
int main()
{
n=rd(); m=rd(); s=; t=n*m+; double l=,r=;
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)w[i][j]=rd(),r+=w[i][j],sum+=w[i][j];
for(int i=;i<=n+;i++)
for(int j=;j<=m;j++)sid[i-][j][i][j]=rd();
for(int i=;i<=n;i++)
for(int j=;j<=m+;j++)sid[i][j-][i][j]=rd();
while(l-r<=eps)
{
double mid=(l+r)*0.5;
if(ck(mid))ans=mid,l=mid+eps;
else r=mid-eps;
}
printf("%.3lf\n",ans);
return ;
}

bzoj 3232 圈地游戏 —— 01分数规划+最小割建图(最大权闭合子图)的更多相关文章

  1. bzoj 3232: 圈地游戏【分数规划+最小割】

    数组开小导致TTTTTLE-- 是分数规划,设sm为所有格子价值和,二分出mid之后,用最小割来判断,也就是判断sm-dinic()>=0 这个最小割比较像最大权闭合子图,建图是s像所有点连流量 ...

  2. bzoj 3232: 圈地游戏 01分数规划

    题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3232 题解: 首先我们看到这道题让我们最优化一个分式. 所以我们应该自然而然地想到01分 ...

  3. zoj 2676 Network Wars 0-1分数规划+最小割

    题目详解出自 论文 Amber-最小割模型在信息学竞赛中的应用 题目大意: 给出一个带权无向图 G = (V,E), 每条边 e属于E都有一个权值We,求一个割边集C,使得该割边集的平均边权最小,即最 ...

  4. HDU 2676 Network Wars 01分数规划,最小割 难度:4

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1676 对顶点i,j,起点s=1,终点t=n,可以认为题意要求一组01矩阵use ...

  5. bzoj 3232: 圈地游戏

    bzoj 3232: 圈地游戏 01分数规划,就是你要最大化\(\frac{\sum A}{\sum B}\),就二分这个值,\(\frac{\sum A}{\sum B} \geq mid\) \( ...

  6. 【BZOJ3232】圈地游戏(分数规划,网络流)

    [BZOJ3232]圈地游戏(分数规划,网络流) 题面 BZOJ 题解 很神仙的一道题. 首先看到最大化的比值很容易想到分数规划.现在考虑分数规划之后怎么计算贡献. 首先每条边的贡献就变成了\(mid ...

  7. BZOJ 3232: 圈地游戏 分数规划+判负环

    3232: 圈地游戏 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 966  Solved: 466[Submit][Status][Discuss] ...

  8. bzoj 3232 圈地游戏——0/1分数规划(或网络流)

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232 当然是0/1分数规划.但加的东西和减的东西不在一起,怎么办? 考虑把它们合在一起.因为 ...

  9. BZOJ.4819.[SDOI2017]新生舞会(01分数规划 费用流SPFA)

    BZOJ 洛谷 裸01分数规划.二分之后就是裸最大费用最大流了. 写的朴素SPFA费用流,洛谷跑的非常快啊,为什么有人还T成那样.. 当然用二分也很慢,用什么什么迭代会很快. [Update] 19. ...

随机推荐

  1. Kubernetes集群中修复状态为NotReady的节点

    度个假回来发现自己集群中的节点都挂了,全部是NotReady状态 但是除了.10节点外,其他主机并没有挂,可以远程连接上, 那就考虑是kubernetes系统的问题 解决的方法是重启kube-prox ...

  2. 【贪心】codeforces A. Heidi and Library (easy)

    http://codeforces.com/contest/802/problem/A [题意] 有一个图书馆,刚开始没有书,最多可容纳k本书:有n天,每天会有人借一本书,当天归还:如果图书馆有这个本 ...

  3. codevs 1743 反转卡片 rope or splay

    [codevs1743]反转卡片 题目描述 Description [dzy493941464|yywyzdzr原创] 小A将N张卡片整齐地排成一排,其中每张卡片上写了1~N的一个整数,每张卡片上的数 ...

  4. [APIO2012] 派遣 dispatching

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 4580  Solved: 2348 Description 在一个忍者的帮派里,一些忍者们被选中派遣给 ...

  5. PatentTips - Solid State Disk (SSD) Device

    BACKGROUND OF THE INVENTION A SSD apparatus is a large-capacity data storage device using a nonvolat ...

  6. 洛谷—— P2812 校园网络

    P2812 校园网络 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮 ...

  7. Linux 特殊文档说明

    目录 /usr/share/man 目录 /usr/share/doc /etc/passwd 文件 /etc/shadow 文件 /etc/group 文件 /usr/share/man 目录 当我 ...

  8. spring 学习资料

    spring 官方教程 1.3.1 http://docs.spring.io/spring/docs/3.1.x/spring-framework-reference/html/index.html ...

  9. soapUI系列之—-07 调用JIRA Rest API接口【例】

    一.调用JIRA接口------实现过滤器搜索问题 1. 在SoapUI中新建 REST Project, 在URI 中输入登录接口的 url (任意一个 Rest 接口的 url 都可以): 2. ...

  10. c#Winform程序调用app.config文件配置数据库连接字符串 SQL Server文章目录 浅谈SQL Server中统计对于查询的影响 有关索引的DMV SQL Server中的执行引擎入门 【译】表变量和临时表的比较 对于表列数据类型选择的一点思考 SQL Server复制入门(一)----复制简介 操作系统中的进程与线程

    c#Winform程序调用app.config文件配置数据库连接字符串 你新建winform项目的时候,会有一个app.config的配置文件,写在里面的<connectionStrings n ...