发现最多有8个限制位置,可以以此为基础DP和容斥。

$f_{i,j}=f_{i-1,j}\times (cnt_j-i+1)+\sum_{k\subset j} f_{i-1,k}$

$cnt_j$表示当限制状态为j时i有多少个可行位置。

这样DP只能保证所有题设位置全部是局部最小值,但不保证其它位置不会变成局部最小值,容斥解决。

$O(DFS*8nm*2^8)$

 #include<cstdio>
#include<cstring>
#include<algorithm>
#define rep(i,l,r) for (int i=(l); i<=(r); i++)
using namespace std; const int mod=;
int dx[]={,,,-,,,-,,-},dy[]={,,,,-,,-,-,};
int n,m,ans,l,f[][<<],cnt[<<],vis[][],a[][];
char ch[][]; int dp(){
memset(f,,sizeof(f));
memset(cnt,,sizeof(cnt));
int top=;
rep(i,,n) rep(j,,m) if (ch[i][j]=='X')
a[++top][]=i,a[top][]=j;
for (int S=; S<(<<top); S++){
memset(vis,,sizeof(vis));
rep(i,,top) if (~S&(<<(i-))) vis[a[i][]][a[i][]]=;
rep(i,,n) rep(j,,m){
bool flag=;
rep(l,,) if (vis[i+dx[l]][j+dy[l]]) { flag=; break; }
if (!flag) cnt[S]++;
}
}
f[][]=;
rep(i,,n*m) for (int j=; j<(<<top); j++){
f[i][j]=(f[i][j]+1ll*f[i-][j]*max(cnt[j]-i+,))%mod;
rep(k,,top) if (j&(<<(k-)))
f[i][j]=(f[i][j]+f[i-][j^(<<(k-))])%mod;
}
return f[n*m][(<<top)-];
} void dfs(int x,int y,int t){
if (y==m+){ dfs(x+,,t); return; }
if (x==n+){ ans=(ans+dp()*(t&?-:))%mod; return; }
dfs(x,y+,t);
bool flag=;
rep(i,,) if (ch[x+dx[i]][y+dy[i]]=='X') { flag=; break; }
if (!flag) ch[x][y]='X',dfs(x,y+,t+),ch[x][y]='.';
} int main(){
freopen("bzoj2669.in","r",stdin);
freopen("bzoj2669.out","w",stdout);
scanf("%d%d",&n,&m);
rep(i,,n) scanf("%s",ch[i]+);
rep(i,,n) rep(j,,m) if (ch[i][j]=='X')
rep(k,,) if (ch[i+dx[k]][j+dy[k]]=='X') { puts(""); return ; }
dfs(,,); printf("%d\n",(ans+mod)%mod);
return ;
}

[BZOJ2669][CQOI2012]局部最小值(容斥+状压DP)的更多相关文章

  1. bzoj2669[cqoi2012]局部极小值 容斥+状压dp

    2669: [cqoi2012]局部极小值 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 774  Solved: 411[Submit][Status ...

  2. ARC 093 F Dark Horse 容斥 状压dp 组合计数

    LINK:Dark Horse 首先考虑1所在位置. 假设1所在位置在1号点 对于此时剩下的其他点的方案来说. 把1移到另外一个点 对于刚才的所有方案来说 相对位置不变是另外的方案. 可以得到 1在任 ...

  3. bzoj3812 主旋律 容斥+状压 DP

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3812 题解 考虑对于图的联通性的 DP 的一般套路:总方案 - 不连通的方案. 那么我们只需要 ...

  4. Comet OJ - Contest #7 C 临时翻出来的题(容斥+状压)

    题意 https://www.cometoj.com/contest/52/problem/C?problem_id=2416 思路 这里提供一种容斥的写法(?好像网上没看到这种写法) 题目要求编号为 ...

  5. 【题解】CQOI2012局部最小值

    上课讲的一道题,感觉也挺厉害的~正解是容斥 + 状压dp.首先我们容易发现一共可能的局部最小值数量是十分有限的,最多也只有 \(8\) 个.所以我们可以考虑状压. 建立出状态 \(f[i][j]\) ...

  6. BZOJ2669 [cqoi2012]局部极小值 状压DP 容斥原理

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ2669 题意概括 有一个n行m列的整数矩阵,其中1到nm之间的每个整数恰好出现一次.如果一个格子比所 ...

  7. 【bzoj2669】[cqoi2012]局部极小值 容斥原理+状压dp

    题目描述 有一个n行m列的整数矩阵,其中1到nm之间的每个整数恰好出现一次.如果一个格子比所有相邻格子(相邻是指有公共边或公共顶点)都小,我们说这个格子是局部极小值. 给出所有局部极小值的位置,你的任 ...

  8. HDU5731 Solid Dominoes Tilings 状压dp+状压容斥

    题意:给定n,m的矩阵,就是求稳定的骨牌完美覆盖,也就是相邻的两行或者两列都至少有一个骨牌 分析:第一步: 如果是单单求骨牌完美覆盖,请先去学基础的插头dp(其实也是基础的状压dp)骨牌覆盖 hiho ...

  9. ARC093F Dark Horse 【容斥,状压dp】

    题目链接:gfoj 神仙计数题. 可以转化为求\(p_1,p_2,\ldots,p_{2^n}\),使得\(b_i=\min\limits_{j=2^i+1}^{2^{i+1}}p_j\)都不属于\( ...

随机推荐

  1. Linux系统网络基础知识及配置

    一:DNS(domain name system)简介 DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而 ...

  2. 4 Values whose Sum is 0 POJ 2785 (折半枚举)

    题目链接 Description The SUM problem can be formulated as follows: given four lists A, B, C, D of intege ...

  3. ribbon使用eureka的meta进行动态路由

    序 使用eureka的元数据信息,再配上ribbon的路由功能,就可以在api-gateway实现很多功能,比如灰度测试.生产调试等等.下面介绍一下,怎么使用jmnarloch大神提供的ribbon- ...

  4. 前端—css

    css css概述 CSS是Cascading Style Sheets的简称,中文称为层叠样式表,用来控制网页数据的表现,可以使网页的表现与数据内容分离. 一.css的四种引入方式: 1.行内式   ...

  5. Opencv模块功能介绍

    本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/   站在巨 ...

  6. Linux 入门记录:十三、Linux 扩展权限

    一.默认权限 每一个终端都有一个 umask 属性,是用来确定新建文件或目录的默认权限的“掩码”(mask 有“掩码”的含义,至于 u,后面说). Linux 中一般有默认的权限掩码,使用命令 uma ...

  7. 64_k2

    kf5-libkdepim-akonadi-17.04.1-1.fc26.x86_64.rpm 25-May-2017 12:22 177198 kf5-libkdepim-devel-17.04.1 ...

  8. sunos kernel src leakrs

    https://github.com/joede/libezV24 https://github.com/ysei/siriusSparcV8 https://github.com/omniti-la ...

  9. mac系统中实现vitualBox中访问内网端口

    第一步,增加外网网段 打开vitualbox后,按管理菜单,点击->主机网络管理器,如图1所示.点击创建,创建下个网络主机. 图1 然后,关掉虚拟机,虚拟机的设置中,找到网络选项卡,然后点击网络 ...

  10. idea和maven使用的点点滴滴

    1.如果在使用maven打包时想跳过单元测试,可以在pom文件中配置如下代码 <build> <plugins> <plugin> <groupId>o ...