http://acm.hdu.edu.cn/showproblem.php?pid=1565

先进行二分图黑白染色,S到黑,白到T,黑到白,问题转化成了求最大权独立集,最大点权独立集=sum-最小点权覆盖集,最小点权覆盖集等于上图最小割

具体解释:

二分图最小点覆盖和最大独立集都可以转化为最大匹配求解。在这个基础上,把每个点赋予一个非负的权值,这两个问题就转化为:二分图最小点权覆盖和二分图最大点权独立集。

二分图最小点权覆盖

从x或者y集合中选取一些点,使这些点覆盖所有的边,并且选出来的点的权值尽可能小。

建模:

原二分图中的边(u,v)替换为容量为INF的有向边(u,v),设立源点s和汇点t,将s和x集合中的点相连,容量为该点的权值;将y中的点同t相连,容量为该点的权值。在新图上求最大流,最大流量即为最小点权覆盖的权值和。

二分图最大点权独立集

在二分图中找到权值和最大的点集,使得它们之间两两没有边。其实它是最小点权覆盖的对偶问题。答案=总权值-最小点覆盖集。具体证明参考胡波涛的论文。

http://yzmduncan.iteye.com/blog/1149057

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std ; const int INF=0xfffffff ;
struct node
{
int s,t,cap,nxt ;
}e[] ;
int m,n,cnt,head[],level[],q[] ;
void add(int s,int t,int cap)
{
e[cnt].s=s ;e[cnt].t=t ;e[cnt].cap=cap ;e[cnt].nxt=head[s] ;head[s]=cnt++ ;
e[cnt].s=t ;e[cnt].t=s ;e[cnt].cap= ;e[cnt].nxt=head[t] ;head[t]=cnt++ ;
}
bool build(int s,int t)
{
int front=,rear= ;
memset(level,-,sizeof(level)) ;
q[rear++]=s ;
level[s]= ;
while(front<rear)
{
int u=q[front++] ;
for(int i=head[u] ;i!=- ;i=e[i].nxt)
{
int tt=e[i].t ;
if(level[tt]==- && e[i].cap>)
{
level[tt]=level[u]+ ;
if(tt==t)return true ;
q[rear++]=tt ;
}
}
}
return false ;
}
int find(int s,int t,int flow)
{
if(s==t)return flow ;
int ret=,a ;
for(int i=head[s] ;i!=- ;i=e[i].nxt)
{
int tt=e[i].t ;
if(level[tt]==level[s]+ && e[i].cap>)
{
a=find(tt,t,min(e[i].cap,flow-ret)) ;
e[i].cap-=a ;
e[i^].cap+=a ;
ret+=a ;
if(ret==flow)
return ret ;
}
}
if(!ret)level[s]=- ;
return ret ;
}
int dinic(int s,int t)
{
int flow,ret= ;
while(build(s,t))
while(flow=find(s,t,INF))
ret+=flow ;
return ret ;
}
int Map[][] ;
int main()
{
int N ;
while(~scanf("%d",&N))
{
cnt= ;
memset(head,-,sizeof(head)) ;
int S,T ;
int sum= ;
for(int i= ;i<=N ;i++)
{
for(int j= ;j<=N ;j++)
{
scanf("%d",&Map[i][j]) ;
sum+=Map[i][j] ;
}
}
S= ;T=N*N+ ;
for(int i= ;i<=N ;i++)
{
for(int j= ;j<=N ;j++)
{
int num=(i-)*N+j ;
if((i+j)&)
{
if(i>)add(num,num-N,INF) ;
if(i<N)add(num,num+N,INF) ;
if(j>)add(num,num-,INF) ;
if(j<N)add(num,num+,INF) ;
add(S,num,Map[i][j]) ;
}
else add(num,T,Map[i][j]) ;
}
}
printf("%d\n",sum-dinic(S,T)) ;
}
return ;
}

最新文章

  1. jdk 编译器 对final字段的处理
  2. 并查集(图论) LA 3644 X-Plosives
  3. QTdebug时没有调试引擎
  4. MySQL_财务统计各产品品类各城市上周收入毛利表_20161202
  5. python数据结构之图深度优先和广度优先
  6. win32多线程-重写消息循环
  7. python实现TCP/UDP通信
  8. CSS实现模糊效果
  9. Dynamics 365 你所期待的子网格编辑终于来了
  10. 大名鼎鼎的红黑树,你get了么?2-3树 绝对平衡 右旋转 左旋转 颜色反转
  11. SQL baseline_11g
  12. LoadRunner开发ftp协议接口之上传文件脚本
  13. 将asp.net mvc的aspx视图转化为Razor视图
  14. [C#]一个简易的、轻量级的方法并行执行线程辅助类
  15. 今天碰到一个问题,怎么限制用户在固定宽度的input输入框里输入的长度,由此涉猎到了maxlength属性和size属性以及它们的区别。
  16. office远程代码执行(CVE-2017-11882)
  17. [UE4]Lock Always
  18. 关于DAL层使用静态方法,并在WEB层直接调用的问题
  19. 使 Inno Setup 打包出的安装程序以管理员身份运行
  20. JavaScript语法对{}的奇葩处理

热门文章

  1. codeforces 350 div2 D Magic Powder - 2 二分
  2. Cocos2d-x学习笔记(十一)动作
  3. go语言 变量类型
  4. MongoDB(课时22 唯一索引)
  5. 小波变化库——Pywalvets学习笔记
  6. js 文件上传
  7. 使用自定义RadioButton和ViewPager实现TabHost效果和带滑动的页卡效果
  8. Unity项目中显示项目的FPS
  9. C#复制文件
  10. pip 源 替换国内源