最大点权独立集,参见胡伯涛论文

#include <iostream>
#include <cstring>
#include <cstdio>
#include <queue>
using namespace std;
int m, n, a[105][105], hea[10005], ss, tt, tot, maxFlow, lev[10005], cnt;
const int oo=0x3f3f3f3f;
const int dx[]={0, 1, 0, -1, 0};
const int dy[]={0, 0, 1, 0, -1};
queue<int> d;
struct Edge{
int too, nxt, val;
}edge[100005];
inline int f(int x, int y){
return n*(x-1)+y;
}
void add_edge(int fro, int too, int val){
edge[cnt].nxt = hea[fro];
edge[cnt].too = too;
edge[cnt].val = val;
hea[fro] = cnt++;
}
void addEdge(int fro, int too, int val){
add_edge(fro, too, val);
add_edge(too, fro, 0);
}
bool bfs(){
memset(lev, 0, sizeof(lev));
lev[ss] = 1;
d.push(ss);
while(!d.empty()){
int x=d.front();
d.pop();
for(int i=hea[x]; i!=-1; i=edge[i].nxt){
int t=edge[i].too;
if(!lev[t] && edge[i].val>0){
lev[t] = lev[x] + 1;
d.push(t);
}
}
}
return lev[tt]!=0;
}
int dfs(int x, int lim){
if(x==tt) return lim;
int addFlow=0;
for(int i=hea[x]; i!=-1 && addFlow<lim; i=edge[i].nxt){
int t=edge[i].too;
if(lev[t]==lev[x]+1 && edge[i].val>0){
int tmp=dfs(t, min(lim-addFlow, edge[i].val));
edge[i].val -= tmp;
edge[i^1].val += tmp;
addFlow += tmp;
}
}
return addFlow;
}
void dinic(){
while(bfs()) maxFlow += dfs(ss, oo);
}
int main(){
memset(hea, -1, sizeof(hea));
cin>>m>>n;
ss = 0; tt = m * n + 1;
for(int i=1; i<=m; i++)
for(int j=1; j<=n; j++)
scanf("%d", &a[i][j]);
for(int i=1; i<=m; i++)
for(int j=1; j<=n; j++){
tot += a[i][j];
if((i+j)&1) addEdge(ss, f(i,j), a[i][j]);
else addEdge(f(i,j), tt, a[i][j]);
for(int k=1; k<=4; k++){
int tx=i+dx[k];
int ty=j+dy[k];
if(tx<1 || tx>m || ty<1 || ty>n) continue;
if((i+j)&1) addEdge(f(i,j), f(tx,ty), oo);
else addEdge(f(tx,ty), f(i,j), oo);
}
}
dinic();
cout<<tot-maxFlow<<endl;
return 0;
}

最新文章

  1. IOS 2D游戏开发框架 SpriteKit--&gt;续(创建用户角色精灵--原创)
  2. Android Volley
  3. 2016年12月29日 星期四 --出埃及记 Exodus 21:24
  4. elk
  5. The Triangle
  6. DLUTOJ 1033 Matrix
  7. Jquery-Ajax常用总结
  8. XML和JSON 序列化以及DataTable转JSON
  9. css3之@font-face---再也不用被迫使用web安全字体了
  10. Java 单文件下载及重命名
  11. [置顶] Oracle 11g R2 RAC:使用 srvctl 工具管理 service 资源
  12. C和C++的学习过程总结
  13. Androidproject夹
  14. Java 并发 线程属性
  15. WEB前端规范命名
  16. Keras官方中文文档:Keras安装和配置指南(Linux)
  17. Java进阶(三十五)java int与integer的区别
  18. 第七周助教工作总结——NWNU李泓毅
  19. yii的ActionForm组件
  20. 【Jenkins】Jenkins安装

热门文章

  1. centos 安装 rtmp nginx 视频流服务器
  2. git如何强制用远程分支更新本地
  3. python读xml文件
  4. npm在linux即mac下更新时报错
  5. COGS 1619. [HEOI2012]采花
  6. poj 3159 Candies (差分约束)
  7. CDOJ 485 UESTC 485 Game (八数码变形,映射,逆cantor展开)
  8. thisnkphp添加二维码
  9. PropertyConfigurer.java
  10. PAT (Basic Level) Practise (中文)-1020. 月饼 (25)