状态压缩DP入门题
.
/*本题为状态压缩题
题目大意 :
一个矩阵里有很多格子,每个格子有两种状态,可以放牧和不可以放牧,
可以放牧用1表示,否则用0表示,在这块牧场放牛,要求两个相邻的方
格不能同时放牛(不包括斜着的),即牛与牛不能相邻。问有多少种放牛方
案(一头牛都不放也是一种方案);
要枚举每一行中的是否种植(也就是0 1状态) 最大状态的12,
每一行的总共可以有的种植方式就有2^12次方种,
而二进制的0 1 特征刚好可以表示这些种植方式;
比如0001 表示在第四个位置种植,其他不种;
比如0101 表示2 4种,依此类推。。。
所以dp[n][m]的第二维度的大小,就要根据题目中的最大限度,
本题n,m的大小开到了12;所以我们以13为上限,或者2^12+10都可以;
dp[n][1<<13];
*/
#include<cstdio>
#include<string.h>
using namespace std;
const int mod=1e8;
const int maxn=<<;
int a[maxn];
int dp[][maxn];
int mp[];
int judge1(int x) //判断同一行中是否会出现相邻为1的情况。
{
return (x&(x<<));
}
int judge2(int i,int x) //判断此情况是否是题目中的可列举情况;
{ //因为题目中有限制哪些地方可以种植,哪些不可以;
return (mp[i]&a[x]);
}
void init() //初始化
{
memset(dp,,sizeof(dp));
memset(mp,,sizeof(mp));
memset(a,,sizeof(a));
}
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF){
init();
for(int i=;i<=n;i++)
for(int j=;j<=m;j++){
int t;
scanf("%d",&t);
if(t==)
mp[i]+=<<(j-); //将题目中每一行的限制情况存储起来;
//这里存储的是不可种植的地方
//后面的判断某种种植方式是否可行的方案
//就可以通过mp[i]&a[x]来解决;
//比如题目中限制了0 1 0 1,表示只有2 4可种植
//而这里是存储了1 0 1 0,现在有个方案是0 1 0 0
//将其与1 0 1 0进行&运行,假如等于0,就表示可行;
}
int cot=;
for(int i=;i<(<<m);i++){
if(!judge1(i))
a[cot++]=i; //将第一行可表示的状态(没有相邻1)列举出来
//此时还未与题目中的限制的可种植地方相比较;
}
for(int i=;i<cot;i++) //与题目限制的相比较;
if(!judge2(,i)) //如果方案可行,=1;
dp[][i]=;
for(int i=;i<=n;i++){
for(int j=;j<cot;j++){
if(judge2(i,j)) //如果不满足限制的种植条件
continue;
for(int k=;k<cot;k++){
if(judge2(i-,k)) //如果不满足限制的种植条件
continue;
if(!(a[k]&a[j]))
dp[i][j]+=dp[i-][k];
}
}
}
int ans=;
for(int i=;i<cot;i++){
ans+=dp[n][i]; //将所有方案相加;
ans%=mod;
}
printf("%d\n",ans);
}
return ;
}
状态压缩DP入门题的更多相关文章
- Hdu-1565 方格取数(1) (状态压缩dp入门题
方格取数(1) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total S ...
- POJ Corn Fields 状态压缩DP基础题
题目链接:http://poj.org/problem?id=3254 题目大意(名称什么的可能不一样,不过表达的意思还是一样的): 种玉米 王小二从小学一年级到现在每次考试都是班级倒数第一名,他的爸 ...
- 状态压缩dp入门
poj1321 http://poj.org/problem?id=1321 我们可以把棋盘的每一行看做是一个状态,如果某一列放置了棋子,那么就标记为1,否则就标记为0.然后把它看成是一个二进制数,然 ...
- POJ3254Corn Fields(状态压缩DP入门)
题目链接 题意:一个矩阵里有很多格子,每个格子有两种状态,可以放牧和不可以放牧,可以放牧用1表示,否则用0表示,在这块牧场放牛,要求两个相邻的方格不能同时放牛,即牛与牛不能相邻.问有多少种放牛方案(一 ...
- 状态压缩dp第一题
标签: ACM 题目: Farmer John has purchased a lush new rectangular pasture composed of M by N (1 ≤ M ≤ 12; ...
- 状态压缩---状态压缩dp第一题
标签: ACM 题目: Farmer John has purchased a lush new rectangular pasture composed of M by N (1 ≤ M ≤ 12; ...
- poj - 3254 Corn Fields (状态压缩dp入门)
http://poj.org/problem?id=3254 参考:http://blog.csdn.net/accry/article/details/6607703 农夫想在m*n的土地上种玉米, ...
- 状态压缩dp 入门
1.有一张n*m (n<=m)的棋盘,在上面放n个中国象棋里的车,使得任意两个车不能相互攻击,总共有多少种不同的方案. 2.有一张n*m (n<=m)的棋盘,其中有些格子里面不能放,在上面 ...
- poj 3254 状压dp入门题
1.poj 3254 Corn Fields 状态压缩dp入门题 2.总结:二进制实在巧妙,以前从来没想过可以这样用. 题意:n行m列,1表示肥沃,0表示贫瘠,把牛放在肥沃处,要求所有牛不能相 ...
随机推荐
- MyEclipse+Tamcat配置
(尊重劳动成果,转载请注明出处:http://blog.csdn.NET/qq_25827845/article/details/53982209 冷血之心的博客) 一.Tomcat 1 Tomcat ...
- C#实例之简单聊天室(状态管理)
前言 状态管理是在同一页或不同页的多个请求发生时,维护状态和页信息的过程.因为Web应用程序的通信协议使用了无状态的HTTP协议,所以当客户端请求页面时,ASP.NET服务器端都会重新生 ...
- ECMAScript基本对象——RegExp 正则表达式对象
含义:定义字符串的组成规则 使用: 1.定义单个字符:[ ] [a] 表示有一个字符是 小写的a [ab] 表示有一个字符是 小写的a或者b [a-z] 表示有一个字符是 小写的a到z [a-z ...
- 如何在Mac OS X上将PDF转换为Microsoft Word
Lighten PDF to Word Converter for Mac是一个简单但功能强大的应用程序,可将PDF文件准确,轻松地转换为Microsoft Word.它可以保留原始内容的布局,格式, ...
- scikit-learn包学习笔记1
dataset 在scikit-learn包自带的数据集,R包也自带数据集iris鸢尾花数据集,做训练集.特征较少. from sklearn import datasets # Import nec ...
- Secondary NameNode:它究竟有什么作用?
前言 最近刚接触Hadoop, 一直没有弄明白NameNode和Secondary NameNode的区别和关系.很多人都认为,Secondary NameNode是NameNode的备份,是为了防止 ...
- 数据库中的sql语句总结
初识SQL 1. 什么是SQL:结构化查询语言(Structured Query Language). 2. SQL的作用:客户端使用SQL来操作服务器. > 启动mysql.exe,连 ...
- easyui datagrid设置排序
sortable="true" order="desc" 或者 sortable:true,order:'desc'
- 5.Docker Compose 部署 Harbor
什么是 Harbor Harbor 是一个用于存储和分发 Docker 镜像的企业级 Registry 服务器,通过添加一些企业必需的功能特性,例如安全.标识和管理等,扩展了开源 Docker Dis ...
- set类型的应用场景 —— Redis实战经验
set类型是string类型的集合,其特点是集合元素无序且不重复,每个集合最多可以存储 232 - 1 个元素(40多亿),set类型主要有以下应用场景. 1. 好友/关注/粉丝/感兴趣的人集合 se ...