poj1038 Bugs Integrated,Inc. (状压dp)
题意:N*M的矩阵,矩阵中有一些坏格子,要在好格子里铺2*3或3*2的地砖,问最多能铺多少个。
我的方法好像和网上流传的方法不太一样...不管了....
由数据范围很容易想到状压dp
我们设某个状态的某一位表示这个格是某种地砖的左上角
那么就会有三种状态,理论上应该用三进制来存储,但我哪会三进制用位运算很方便于是就用2位二进制数来代替1位三进制数...
用00代表没有地砖,01代表铺了个2*3的地砖,10代表铺了个3*2的地砖
然后为了节约空间和时间,先对一个空行dfs一遍,得到这一行可能的地砖铺法,存储下来方便以后枚举状态(M=10时总共有274种状态)
然后设f[i][j][k]为第i行,状态为j,上一行状态为k的地砖数量
然后f[i][j][k]=max{f[i-1][k][l]},枚举k,l,然后判断符合不符合条件即可
为了防止爆内存可以用unsigned char强行卡用滚动数组(我第一次还真是用unsigned char强行卡过的..因为总共数量最多也就10*150/6=250种)
说着轻巧但是好难判啊
然后我不小心输出答案时用了%lld结果一直WA???求解答...
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#include<cmath>
#define inf 0x3f3f3f3f
#define LL long long int
using namespace std;
const int maxm=,maxn=,maxs=;
const int f11=,f01=;
const int b0101=,b101010=,b11=,b1111=,b111111=; inline LL rd(){
LL x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} int sta[maxs],fsta[maxs],sct,mp[maxn];
int f[][maxs][maxs];
int N,M,K;char num[maxs]; inline void print(int x,int y){
if(y<=M*-) print(x>>,y+);
printf("%d",x&);
} void dfs(int x,int s,int fs,int c){
if(x>=M){sta[++sct]=s;fsta[sct]=fs;num[sct]=c;return;}
dfs(x+,s,fs,c);
if(x<=M-){
dfs(x+,s|(b0101<<(x<<)),fs|(b1111<<(x<<)),c+);
}if(x<=M-){
dfs(x+,s|(b101010<<(x<<)),fs|(b111111<<(x<<)),c+);
}
} inline bool judge1(int i,int s){
return (s&(mp[i]|mp[i+]))||(s&f01&mp[i+]);
} int main(){
//freopen("1038.in","r",stdin);
int i,j,k,l;
for(int t=rd();t;t--){
N=rd(),M=rd(),K=rd();
memset(mp,,sizeof(mp));
sct=;dfs(,,,);
for(i=;i<=K;i++){
int a=rd(),b=rd();
mp[a-]|=b11<<((b-)<<);
}mp[N+]=mp[N]=f11;
bool b=;
for(i=;i<N-;i++){
memset(f[b],-,sizeof(f[b]));
for(j=;j<=sct;j++){
if(judge1(i,sta[j])) continue;
if(!i){f[b][j][]=num[j];continue;}
for(k=;k<=sct;k++){
if((sta[j]&fsta[k])||judge1(i-,sta[k])) continue;
for(l=;l<=sct;l++){
if(fsta[j]&(sta[l]&f01)) continue;
f[b][j][k]=max(f[b][j][k],f[b^][k][l]);
}if(f[b][j][k]==-) continue;
f[b][j][k]+=num[j];
}
}b^=;
}int ans=;
for(i=;i<=sct;i++){
for(j=;j<=sct;j++) ans=max(ans,f[b^][i][j]);
}printf("%d\n",ans);
}
return ;
}
poj1038 Bugs Integrated,Inc. (状压dp)的更多相关文章
- POJ1038 Bugs Integrated, Inc 状压DP+优化
(1) 最简单的4^10*N的枚举(理论上20%) (2) 优化优化200^3*N的枚举(理论上至少50%) (3) Dfs优化状压dp O(我不知道,反正过不了,需要再优化)(理论上80%) (4) ...
- POJ 1038 Bugs Integrated, Inc. ——状压DP
状态压缩一下当前各格子以及上面总共放了几块,只有012三种情况,直接三进制保存即可. 然后转移的时候用搜索找出所有的状态进行转移. #include <map> #include < ...
- POJ1038 - Bugs Integrated, Inc.(状态压缩DP)
题目大意 要求你在N*M大小的主板上嵌入2*3大小的芯片,不能够在损坏的格子放置,问最多能够嵌入多少块芯片? 题解 妈蛋,这道题折腾了好久,黑书上的讲解看了好几遍才稍微有点眉目(智商捉急),接着看了网 ...
- poj2411 Mondriaan's Dream[简单状压dp]
$11*11$格子板上铺$1*2$地砖方案.以前做过?权当复习算了,毕竟以前学都是浅尝辄止的..常规题,注意两个条件:上一行铺竖着的则这一行同一位一定要铺上竖的,这一行单独铺横的要求枚举集合中出现连续 ...
- POJ 1038 Bugs Integrated Inc (复杂的状压DP)
$ POJ~1038~~\times Bugs~Integrated~Inc: $ (复杂的状压DP) $ solution: $ 很纠结的一道题目,写了大半天,就想练练手,结果这手生的.其实根据之前 ...
- [POJ1038]状压DP
题意:给一个n*m的区域,里面有一些障碍物,往里面放2*3和3*2的矩形,矩形之间不能重叠,不能覆盖到障碍物,求能放置的最大个数.(n<=150,m<=10) 思路:看到m=10就应该往状 ...
- POJ1038 Bugs Integrated, Inc.
题目来源:http://poj.org/problem?id=1038 题目大意: 有一家芯片公司要在一块N*M的板子上嵌入芯片,其中1<=N<=150, 1<=M<=10,但 ...
- BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3336 Solved: 1936[Submit][ ...
- nefu1109 游戏争霸赛(状压dp)
题目链接:http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=1109 //我们校赛的一个题,状压dp,还在的人用1表示,被淘汰 ...
随机推荐
- Luogu P4053 [JSOI2007]建筑抢修
一道贪心题,看数据范围就知道要套一个数据结构上去. 别走啊不是什么很高级的数据结构 考虑最朴素的想法,按建筑的抢修时间排序并先拿小的 然后随便想想都可以找到一堆反例 所以我们就直接考虑模拟这个过程,按 ...
- [Python]Hamming distance 问题
In [75]: x=4 In [76]: y=1 In [77]: str(bin(x ^ y))[2:].count('1') Out[77]: 2 In [78]: 来自:https://lee ...
- JVM规范系列第4章:Class文件格式
这一章节讲的是字节码的整个组成格式,读懂了这一章,就读懂了字节码文件.对于这一章的学习,我更推荐作为工具书去查找.最好是找一个最简单的Hello World例子,一个字节一个字节去分析其含义.在分析过 ...
- Spring+SpringMVC+MyBatis+easyUI整合进阶篇(十二)Spring集成Redis缓存
作者:13 GitHub:https://github.com/ZHENFENG13 版权声明:本文为原创文章,未经允许不得转载. 整合Redis 本来以为类似的Redis教程和整合代码应该会很多,因 ...
- 浅谈nornalize.css(含源码)
Normalize.css是一种CSS reset的替代方案.经过@necolas和@jon_neal花了几百个小时来努力研究不同浏览器的默认样式的差异,这个项目终于变成了现在这样. 我们创造norm ...
- 本地开发环境搭建(windows)
一.虚拟器安装 1.概念 ・为什么要搭建搭建模拟环境 在租借服务器前用手中的PC模拟一个服务器的环境,可以打包与团队人员分享 ・什么是Vagrant https://segmentfault.com/ ...
- PAT甲题题解-1129. Recommendation System (25)-排序
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6789819.html特别不喜欢那些随便转载别人的原创文章又不给 ...
- 个人博客Week3——案例分析
一.调研,评测 我使用的bing的WINDOWS客户端,其大致分为四个模块:词典.例句.翻译.应用. (1)“词典”模块 BUG:搜索”http“词条,界面显示http的相关,但是无法再回到最初的主界 ...
- Hangfire Net Core2
https://hangfire.jonecheung.win/configuration/using-redis.html Hangfire 官方支持 MSSQL 与 Redis(Hangfire. ...
- mac安装sublime text 3,含注册码
软件下载地址: https://www.sublimetext.com/3 注册码如下: —– BEGIN LICENSE —– TwitterInc 200 User License EA7E-89 ...