状态压缩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表示贫瘠,把牛放在肥沃处,要求所有牛不能相 ...
随机推荐
- web服务器的解析漏洞罗列
前言 服务器相关中间件存在一些解析漏洞,攻击者可通过上传一定格式的文件,被服务器的中间件进行了解析,这样就对系统造成一定危害.常见的服务器解析漏洞涉及的中间件有IIS,apache.nginx等.可利 ...
- PAT (Basic Level) Practice (中文)1016 部分A+B (15 分)
正整数 A 的“DA(为 1 位整数)部分”定义为由 A 中所有 DA 组成的新整数 PA.例如:给定 8,DA=6,则 A 的“6 部分”PA 是 66,因为 A 中有 ...
- Cloud开发动态列的简单账表
业务场景:客户需要根据过滤条件的不同显示不同的列.如下方式可以实现动态的列名. using System;using System.Collections.Generic;using System.L ...
- 爬虫爱用的一些python技巧
1.正则表达式 有时候提取到的数据不规整,需要用正则来匹配所需要展现出来的数据 学习链接:https://www.cnblogs.com/-chenxs/p/11352172.html,https:/ ...
- 在vue项目中设置BASE_URL
在vue项目中设置BASE_URL 1.在config文件夹中新建global.js文件 const BASE_URL = 'http://192.168.1.62:8080/rest/' expor ...
- dubbo的服务consumer与provider使用的api版本不一致,是否有影响
dubbo的服务consumer与provider使用的api版本不一致,是否有影响 最近新接手一个项目,看到定义的dubbo接口有些很奇葩的设定. 一.消费端 与 服务端 调用的接口中的数据包装类型 ...
- POJ 2096 Collecting Bugs (概率DP,求期望)
Ivan is fond of collecting. Unlike other people who collect post stamps, coins or other material stu ...
- 我的第一个Maven Helloworld
使用MAVEN创建项目可以有两种方式进行创建,第一种,使用mvn命令创建Maven项目,第二种,使用eclipse创建Maven项目. 在创建Maven项目之前,我们需要安装maven,并和配置JDK ...
- Vue中封装axios
参考: https://www.jianshu.com/p/7a9fbcbb1114 https://www.cnblogs.com/dreamcc/p/10752604.html 一.安装axios ...
- MariaDB 安装配置记录
1.集群搭建记录 iptables --append INPUT --protocol tcp \ --source 192.168.126.129 --jump ACCEPT iptables -- ...