【题目大意】

给定一个01矩阵,其中你可以在0的位置放置攻击装置。每一个攻击装置(x,y)都可以按照“日”字攻击其周围的 8个位置(x-1,y-2),(x-2,y-1),(x+1,y-2),(x+2,y-1),(x-1,y+2),(x-2,y+1), (x+1,y+2),(x+2,y+1)。
求在装置互不攻击的情况下,最多可以放置多少个装置。

【思路】

最大独立集=总点数-最大二分图匹配

我们都知道最大独立集一般用在二分图里…所以把每个点看作两个点,一个是从它出发,一个是抵达它。实际操作的时候因为会连正反边,不需要进行拆点。最大独立集=总点数-最大二分图匹配/2。

 #include<bits/stdc++.h>
using namespace std;
const int MAXN=;
int n,maps[MAXN][MAXN];
int lk[MAXN*MAXN],vis[MAXN*MAXN];
vector<int> E[MAXN*MAXN]; int check(int x,int y)
{
if (x>= && x<=n && y>= && y<=n && maps[x][y]) return ;else return ;
} int id(int x,int y){return ((x-)*n+y);} void addedge(int u,int v)
{
E[u].push_back(v);
} int find(int u)
{
for (int i=E[u].size()-;i>=;i--)
{
int v=E[u][i];
if (!vis[v])
{
vis[v]=;
if (!lk[v]|| find(lk[v]))
{
lk[v]=u;
return ;
}
}
}
return ;
} void init()
{
scanf("%d",&n);
for (int i=;i<=n;i++)
{
char str[MAXN];
scanf("%s",str);
for (int j=;j<n;j++)
if (str[j]=='') maps[i][j+]=;else maps[i][j+]=;
}
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
if (maps[i][j]==)
{
if (check(i-,j-)) addedge(id(i,j),id(i-,j-));
if (check(i-,j-)) addedge(id(i,j),id(i-,j-));
if (check(i+,j-)) addedge(id(i,j),id(i+,j-));
if (check(i+,j-)) addedge(id(i,j),id(i+,j-));
if (check(i-,j+)) addedge(id(i,j),id(i-,j+));
if (check(i-,j+)) addedge(id(i,j),id(i-,j+));
if (check(i+,j+)) addedge(id(i,j),id(i+,j+));
if (check(i+,j+)) addedge(id(i,j),id(i+,j+));
}
} void solve()
{
memset(lk,,sizeof(lk));
int sum=,ans=;
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
{
if (maps[i][j]==)
{
int x=id(i,j);
memset(vis,,sizeof(vis));
sum++;
if (find(x)) ans++;
}
}
printf("%d",sum-ans/);//不要忘记了除以2
} int main()
{
init();
solve();
}

最新文章

  1. Django进阶(三)
  2. ZooKeeper 笔记(3) 实战应用之【统一配置管理】
  3. eclipse中运行python脚本中有注释为中文的内容,报错:SyntaxError: Non-ASCII character &#39;\xe5&#39;
  4. mysql-关于Unix时间戳(unix_timestamp)
  5. apiCloud授权绑定第三方账号,微信、QQ、微博。
  6. HDU 4282 A very hard mathematic problem 二分
  7. ZOJ1025-最长下降子序列
  8. c# 使用递归 循环遍历导航树结构 并解析
  9. web打印小结
  10. 15、手把手教你Extjs5(十五)各种Grid列的自定义渲染
  11. mybatis-枚举类型的typeHandler&amp;自定义枚举类型typeHandler
  12. sbadmin表单事件
  13. Nginx使用教程(三):Nginx配置性能优化之I/O和TCP配置
  14. 2016年3月16日Android学习笔记
  15. 【C#小知识】C#中一些易混淆概念总结(七)---------解析抽象类,抽象方法
  16. (转)使用 Nmon 监控 Linux 的系统性能
  17. Android实用代码片段
  18. 创龙OMAPL138开发板测试(1)
  19. 虚机启动失败-Event 1069
  20. Tomcat7中开启gzip压缩功能的配置方法

热门文章

  1. 解决ajax chrome禁止本地浏览时加载本地其他文件的方法
  2. Javascript装饰器的妙用
  3. Pyrhon代码的中文问题
  4. kvm 简单了解
  5. videojs做直播、弹幕
  6. C# 获取mp3文件的歌曲时间长度
  7. c++各种排序的简单实现
  8. Freemaker 自定义指令和函数
  9. sort排序命令常见用法
  10. 制作一棵ztree