hdu 5556 Land of Farms 最大团+暴力
Land of Farms
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 539 Accepted Submission(s): 177
Farmer John wants to build as many farms as possible on the new land. It is required that any two farms should not be adjacent. Otherwise, sheep from different farms would fight on the border. This should be an easy task until several ancient farms are discovered.
Each of the ancient farms also consists of one or more connected grids. Due to the respect to the ancient farmers, Farmer John do not want to divide any ancient farm. If a grid from an ancient farm is selected in a new farm, other grids from the ancient farm should also be selected in the new farm. Note that the ancient farms may be adjacent, because ancient sheep do not fight each other.
The problem is a little complicated now. Can you help Farmer John to find a plan with the maximum number of farms?
Each test case starts with a line containing two integers N and M, indicating the size of the land. Each of the following N lines contains M characters, describing the map of the land (1≤N,M≤10). A grid of an ancient farm is indicated by a single digit (0-9). Grids with the same digit belong to the same ancient farm. Other grids are denoted with a single character “.”. It is guaranteed that all test cases are valid.
3 4
..3.
023.
.211
2 3
...
...
4 4
1111
1..1
1991
1111
Case #2: 3
Case #3: 1
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <iostream>
#include <cmath>
#include <map>
#include <bitset>
#include <stack>
#include <queue>
#include <vector>
#include <bitset>
#include <set>
#define MM(a,b) memset(a,b,sizeof(a));
#define inf 0x3f3f3f3f
using namespace std;
typedef long long ll;
#define CT continue
#define SC scanf char f[15][15];
int anc[16],flag[14],mp[12][12],cnta,ans,res;
int dx[]={0,0,1,-1},dy[]={1,-1,0,0},match[105],used[105];
vector<int> G[205];
int cas,r,l;
bitset<15> sta; void add_edge(int u,int v)
{
G[u].push_back(v);
G[v].push_back(u);
//if(sta==0) cout<<"u: "<<u<<" v:"<<v<<"\n";
} bool dfs(int u)
{
used[u]=1;
for(int i=0;i<G[u].size();i++){
int v=G[u][i],w=match[v];
if(w<0||(!used[w]&&dfs(w))){
match[u]=v;
match[v]=u;
return true;
}
}
return false;
} int bi_mactch()
{
int res=0;
MM(match,-1);
for(int i=1;i<=r;i++) for(int j=1;j<=l;j++){
int k=(i-1)*l+j;
if(match[k]<0){
MM(used,0);
if(dfs(k)) res++;
}
}
return res;
} int par[15]; int findr(int u)
{
if(par[u]!=u)
par[u]=findr(par[u]);
return par[u];
} void unite(int u,int v)
{
int ru=findr(u),rv=findr(v);
if(ru!=rv) par[ru]=rv;
} int num=0;
void sear(int i,int j)
{
if(f[i][j]>='0'&&f[i][j]<='9'){
int k=f[i][j]-'0';
if(!flag[k]) return;
mp[i][j]=-1;
for(int d=0;d<4;d++){
int tx=i+dx[d],ty=j+dy[d];
if(f[tx][ty]>='0'&&f[tx][ty]<='9'){
int k2=f[tx][ty]-'0';
if(flag[k2]) unite(k,k2);
}
else if(f[tx][ty]=='.') mp[tx][ty]=-1;
}
}
} void bgraph()
{
for(int i=1;i<=110;i++) G[i].clear();
for(int i=1;i<=r;i++)
for(int j=1;j<=l;j++)
if(f[i][j]=='.'&&!mp[i][j]){
num++;
int k=(i-1)*l+j;
//if(sta==0) cout<<"kk:"<<k<<"\n";
if(f[i-1][j]=='.'&&!mp[i-1][j]) add_edge(k,k-l);
if(f[i][j-1]=='.'&&!mp[i][j-1]) add_edge(k,k-1);
}
} void solve()
{
ans=0;
for(int k=0;k<=(1<<cnta)-1;k++){
res=0;MM(mp,0);MM(flag,0);
sta=k;
for(int i=0;i<cnta;i++) if(sta[i]) {
int w=anc[i+1];flag[w]=1;
par[w]=w;
}
for(int i=1;i<=r;i++) for(int j=1;j<=l;j++) sear(i,j);
for(int i=1;i<=cnta;i++)
if(flag[anc[i]]&&par[anc[i]]==anc[i]) res++;
num=0;bgraph();
ans=max(ans,res+num-bi_mactch());
}
} int main()
{
SC("%d",&cas);
int kk=0;
while(cas--){
SC("%d%d",&r,&l);
MM(flag,0);
cnta=0;
for(int i=1;i<=r;i++) {
SC("%s",f[i]+1);
for(int j=1;j<=l;j++)
if(f[i][j]!='.'){
int k=f[i][j]-'0';
if(!flag[k]){
flag[k]=1;
anc[++cnta]=k;
}
}
}
solve();
printf("Case #%d: %d\n",++kk,ans);
}
return 0;
}
分析:
1.先2^10=10^3暴力枚举选择的古代的田,选择了后,在用并查集维护一下,能产生的牧田数。
2.删除选择的古代的田周围的普通田地,再用下网格的二分图,考虑不想邻的连接一条边,那么最后显然成成了,求这样一个最大团
3.二分图的最大团=补图的最大点独立集合=顶点数-最大匹配数
hdu 5556 Land of Farms 最大团+暴力的更多相关文章
- Land of Farms HDU - 5556 二分图匹配
Farmer John and his brothers have found a new land. They are so excited and decide to build new farm ...
- 【HDOJ5556】Land of Farms(最大团)
题意:给定n*m的网格图,上面只有字符'.' 和 数字0-9.其中数字表示这是该格是古老的土地,字符'.'表示该格只是普通的土地. 可以认为一块古老的农田由四联通的所有数字相同的格组成的块,一块普通的 ...
- hdu 4740 The Donkey of Gui Zhou(暴力搜索)
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4740 [题意]: 森林里有一只驴和一只老虎,驴和老虎互相从来都没有见过,各自自己走过的地方不能走第二次 ...
- hdu 3183 A Magic Lamp rmq或者暴力
A Magic Lamp Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Pro ...
- HDU 6395 Sequence 【矩阵快速幂 && 暴力】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=6395 Sequence Time Limit: 4000/2000 MS (Java/Others) ...
- 「国庆训练&知识学习」图的最大独立集与拓展(Land of Farms,HDU-5556)
题意 一个\(N*M\)的矩阵,其中"."代表空地,"0-9"代表古代建筑,我们如果选择了一个编号的古代建筑想要建立,那么对应就要将全部该编号的建筑建立起来,如 ...
- HDU 4462:Scaring the Birds(暴力枚举+状态压缩)
http://acm.hdu.edu.cn/showproblem.php?pid=4462 题意:有一个n*n的地图,有k个空地可以放稻草人,给出每个空地可以放的稻草人属性,属性中有个R代表这个位置 ...
- HDU 6697 Closest Pair of Segments (计算几何 暴力)
2019 杭电多校 10 1007 题目链接:HDU 6697 比赛链接:2019 Multi-University Training Contest 10 Problem Description T ...
- HDU 3267 Graph Game(博弈论+图论+暴力)
题面传送门 题意: 有一棵 \(n\) 个节点的图 \(G\),R 和 B 两个人轮流操作,R 先操作. 每次操作 R 可以染红任意一条未染色的边,B 可以染蓝任意一条未染色的边 R 的目标是染成一棵 ...
随机推荐
- Laravel三种中间件的作用
$middleware 属性: 这个属性称为全局中间件,为什么说是全局中间件呢?因为你的每一次请求,这里面的每个中间件都会执行. $routeMiddleware 属性: 这个属性称为路由中间件,为什 ...
- k8s-搭建 EFK 日志系统
搭建 EFK 日志系统 大家介绍了 Kubernetes 集群中的几种日志收集方案,Kubernetes 中比较流行的日志收集解决方案是 Elasticsearch.Fluentd 和 Kibana( ...
- 记笔记的软件(vnote)
前面我们已经把我们的 Ubuntu 系统在物理机上运行起来了,也做了一些简单的优化,教了大家怎么使用 Ubuntu 系统自带的应用商店和 apt 安装和卸载软件.接着我们安装了搜狗输入法,现在我们的系 ...
- 怎样查看Redis的版本号
Q: 怎样查看Redis版本 A: 下面两条命令都可以查看redis 版本: redis-server --version redis-server -v
- 怎样通过CSS选择器获取元素节点或元素节点集合
使用 document.querySelector() 和 document.querySelectorAll(), 将 CSS选择器 作为参数传入即可. // 标签选择器 document.quer ...
- oracle_多表查询02
多表查询 select * from BONUS; select * from DEPT; select * from EMP; select * from SALGRADE; BONUS表 ENAM ...
- springboot application.properties配置大全
springboot application.properties配置大全 官方文档 https://docs.spring.io/spring-boot/docs/current/reference ...
- Spring在Thread中注入Bean无效的解决方式
在Spring项目中,有时需要新开线程完成一些复杂任务,而线程中可能需要注入一些服务.而通过Spring注入来管理和使用服务是较为合理的方式.但是若直接在Thread子类中通过注解方式注入Bean是无 ...
- Django中 auto_now_add 和 auto_now 的区别
auto_now_add = True #创建时添加的时间 修改数据时,不会发生改变 auto_now = True #修改数据的时间,每次修改都会有变动 ........
- Android opengl 笔记
1. varying vec2 vTextureCoord; 不能用in vec2 ,varying 表示在vs 和 fs中都可见. 2. android 里面 0 和1 都要打小数点 比如0.0 1 ...