【bzoj3175】[Tjoi2013]攻击装置
每两个能互相攻击且能放置的点连一条双向边,然后跑二分图最大点独立集即可
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std; typedef long long LL; #define M 80010
#define N 210 struct edge
{
int to,next;
}e[M<<1];
int head[M<<1];
int cnt; int ly[M]; int a[N][N],flag[M]; char s[N]; int dx[]={1,1,2,2};
int dy[]={2,-2,1,-1}; int n,q;
int tot,ans; void link(int x,int y)
{
e[++cnt]=(edge){y,head[x]};
head[x]=cnt;
} bool find(int x)
{
for (int i=head[x];i;i=e[i].next)
{
int t=e[i].to;
if (flag[t]!=q)
{
flag[t]=q;
if (!ly[t] || find(ly[t]))
{
ly[t]=x;
return true;
}
}
}
return false;
} int main()
{
scanf("%d",&n);
for (int i=1;i<=n;i++)
{
scanf("%s",s+1);
for (int j=1;j<=n;j++)
if (s[j]=='0')
a[i][j]=++tot;
else
a[i][j]=0;
}
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if (a[i][j])
for (int k=0;k<4;k++)
{
int x=i+dx[k],y=j+dy[k];
if (x<1 || x>n || y<1 || y>n)
continue;
if (a[x][y])
link(a[i][j],a[x][y]),link(a[x][y],a[i][j]);
}
for (int i=1;i<=tot;i++)
{
q++;
if (find(i))
ans++;
}
printf("%d\n",tot-ans/2);
return 0;
}
【bzoj3175】[Tjoi2013]攻击装置的更多相关文章
- bzoj4808: 马 & bzoj3175: [Tjoi2013]攻击装置 (黑白染色+最小割)
		bzoj4808: 马 & bzoj3175: [Tjoi2013]攻击装置 题目:传送门 简要题意: 和n皇后问题差不多,但是这里是每个棋子走日子,而且有些格子不能放棋子.求最多能放多少个棋 ... 
- BZOJ3175: [Tjoi2013]攻击装置
		题解: 最大点独立集...好像水过头了... 不过发现我二分图好像忘完了!!! 代码: #include<cstdio> #include<cstdlib> #include& ... 
- BZOJ3175 Tjoi2013 攻击装置(二分图匹配)
		传送门 Description 给定一个01矩阵,其中你可以在0的位置放置攻击装置.每一个攻击装置(x,y)都可以按照"日"字攻击其周围的 8个位置(x-1,y-2),(x-2,y ... 
- BZOJ3175[Tjoi2013]攻击装置——二分图最大独立集
		题目描述 给定一个01矩阵,其中你可以在0的位置放置攻击装置.每一个攻击装置(x,y)都可以按照“日”字攻击其周围的 8个位置(x-1,y-2),(x-2,y-1),(x+1,y-2),(x+2,y- ... 
- BZOJ3175:[TJOI2013]攻击装置(二分图最大独立集)
		Description 给定一个01矩阵,其中你可以在0的位置放置攻击装置.每一个攻击装置(x,y)都可以按照“日”字攻击其周围的 8个位置(x-1,y-2),(x-2,y-1),(x+1,y-2), ... 
- bzoj3175: [Tjoi2013]攻击装置&&4808: 马
		终于知道为啥网络流这么受欢迎了. 其实就是构个图模板一下的事儿,比较好打是吧. 然后这题网络流黑白染色(其实感觉上匈牙利更加直接好想啊,但是实际上黑白染色给人感觉就是二分图) st连白而ed连黑,流量 ... 
- 【BZOJ4808/3175】马/[Tjoi2013]攻击装置 最小割
		[BZOJ4808]马 Description 众所周知,马后炮是中国象棋中很厉害的一招必杀技."马走日字".本来,如果在要去的方向有别的棋子挡住(俗称"蹩马腿" ... 
- BZOJ 3175: [Tjoi2013]攻击装置( 匈牙利 )
		黑白染成二分图, 然后不能同时选的就连边, 最大匹配数为m, t为不能放的数目, 则题目所求最大点独立集为 n*n-m-t -------------------------------------- ... 
- 【洛谷】4304:[TJOI2013]攻击装置【最大点独立集】【二分图】2172: [国家集训队]部落战争【二分图/网络流】【最小路径覆盖】
		P4304 [TJOI2013]攻击装置 题目描述 给定一个01矩阵,其中你可以在0的位置放置攻击装置. 每一个攻击装置(x,y)都可以按照“日”字攻击其周围的8个位置(x-1,y-2),(x-2,y ... 
- 【BZOJ 3175】 3175: [Tjoi2013]攻击装置(二分图匹配)
		3175: [Tjoi2013]攻击装置 Description 给定一个01矩阵,其中你可以在0的位置放置攻击装置.每一个攻击装置(x,y)都可以按照“日”字攻击其周围的 8个位置(x-1,y-2) ... 
随机推荐
- [Kubernetes]Pod字段自动填充
			PodPreset(Pod预设置)在Kubernetes v1.11以后出现,开发人员只需要提交一个基本的Pod YAML,Kubernetes就可以自动给对应的Pod对象加上运维人员设定好的其他必要 ... 
- jenkins+jacoco+ant+apache集成统计web端功能测试覆盖率
			一.覆盖率定义 作为一个测试人员,保证产品的软件质量是其工作首要目标,为了这个目标,测试人员常常会通过很多手段或工具来加以保证,覆盖率就是其中一环比较重要的环节. 我们通常会将测试覆盖率分为两个部分, ... 
- [UOJ#130][BZOJ4198][Noi2015]荷马史诗
			[UOJ#130][BZOJ4198][Noi2015]荷马史诗 试题描述 追逐影子的人,自己就是影子. ——荷马 Allison 最近迷上了文学.她喜欢在一个慵懒的午后,细细地品上一杯卡布奇诺,静静 ... 
- java.lang.Class解析
			java.lang.Class 1.java.lang.Class的概念 当一个类或接口被装入的JVM时便会产生一个与之关联的java.lang.Class对象,java.lang.class类就是用 ... 
- java面试题之简单介绍一下集合框架
			集合框架分为三块:List列表.Set集合.Map映射 List列表在数据结构上可以被看做线性表,常用的有ArrayList和LinkList(不常用的有Vector(类似于ArrayList)),他 ... 
- 改变input的value值,同时在HTML中将value进行改变
			在使用lodop进行打印的时候,需求中有这样一个功能:某个字段可以在页面的input框中进行修改. 但是在进行打印时调用的是静态的HTML代码,这就导致在页面的input框中改变字段之后,但是HTML ... 
- Python入门--2--继续学习
			继续学习小甲鱼 一.python比较操作符 == :判断左边是否等于右边 != : 判断左边是否不能右边 二. if while判断语句 栗子: temp = input ("sha shu ... 
- saltstack 开发相关命令记录
			SALT API开发相关命令记录. 查看当前的salt key信息salt-key -L 测试被控主机的连通性salt '*' test.ping 远程命令执行测试salt '*' cmd.run ' ... 
- Spring Boot 2 快速教程:WebFlux 集成 Mongodb(四)
			摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第104篇原创 文章工程:* JDK 1.8* M ... 
- Hadoop三种模的安装配置过程
			JDK+Hadoop安装配置.单机模式配置 以下操作在SecureCRT里面完成 1.关闭防火墙 firewall-cmd --state 显示防火墙状态running/not running sys ... 
