.

 /*本题为状态压缩题
题目大意 :
一个矩阵里有很多格子,每个格子有两种状态,可以放牧和不可以放牧,
可以放牧用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入门题的更多相关文章

  1. Hdu-1565 方格取数(1) (状态压缩dp入门题

    方格取数(1) Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  2. POJ Corn Fields 状态压缩DP基础题

    题目链接:http://poj.org/problem?id=3254 题目大意(名称什么的可能不一样,不过表达的意思还是一样的): 种玉米 王小二从小学一年级到现在每次考试都是班级倒数第一名,他的爸 ...

  3. 状态压缩dp入门

    poj1321 http://poj.org/problem?id=1321 我们可以把棋盘的每一行看做是一个状态,如果某一列放置了棋子,那么就标记为1,否则就标记为0.然后把它看成是一个二进制数,然 ...

  4. POJ3254Corn Fields(状态压缩DP入门)

    题目链接 题意:一个矩阵里有很多格子,每个格子有两种状态,可以放牧和不可以放牧,可以放牧用1表示,否则用0表示,在这块牧场放牛,要求两个相邻的方格不能同时放牛,即牛与牛不能相邻.问有多少种放牛方案(一 ...

  5. 状态压缩dp第一题

    标签: ACM 题目: Farmer John has purchased a lush new rectangular pasture composed of M by N (1 ≤ M ≤ 12; ...

  6. 状态压缩---状态压缩dp第一题

    标签: ACM 题目: Farmer John has purchased a lush new rectangular pasture composed of M by N (1 ≤ M ≤ 12; ...

  7. poj - 3254 Corn Fields (状态压缩dp入门)

    http://poj.org/problem?id=3254 参考:http://blog.csdn.net/accry/article/details/6607703 农夫想在m*n的土地上种玉米, ...

  8. 状态压缩dp 入门

    1.有一张n*m (n<=m)的棋盘,在上面放n个中国象棋里的车,使得任意两个车不能相互攻击,总共有多少种不同的方案. 2.有一张n*m (n<=m)的棋盘,其中有些格子里面不能放,在上面 ...

  9. poj 3254 状压dp入门题

    1.poj 3254  Corn Fields    状态压缩dp入门题 2.总结:二进制实在巧妙,以前从来没想过可以这样用. 题意:n行m列,1表示肥沃,0表示贫瘠,把牛放在肥沃处,要求所有牛不能相 ...

随机推荐

  1. web服务器的解析漏洞罗列

    前言 服务器相关中间件存在一些解析漏洞,攻击者可通过上传一定格式的文件,被服务器的中间件进行了解析,这样就对系统造成一定危害.常见的服务器解析漏洞涉及的中间件有IIS,apache.nginx等.可利 ...

  2. PAT (Basic Level) Practice (中文)1016 部分A+B (15 分)

    正整数 A 的“D​A​​(为 1 位整数)部分”定义为由 A 中所有 D​A​​ 组成的新整数 P​A​​.例如:给定 8,D​A​​=6,则 A 的“6 部分”P​A​​ 是 66,因为 A 中有 ...

  3. Cloud开发动态列的简单账表

    业务场景:客户需要根据过滤条件的不同显示不同的列.如下方式可以实现动态的列名. using System;using System.Collections.Generic;using System.L ...

  4. 爬虫爱用的一些python技巧

    1.正则表达式 有时候提取到的数据不规整,需要用正则来匹配所需要展现出来的数据 学习链接:https://www.cnblogs.com/-chenxs/p/11352172.html,https:/ ...

  5. 在vue项目中设置BASE_URL

    在vue项目中设置BASE_URL 1.在config文件夹中新建global.js文件 const BASE_URL = 'http://192.168.1.62:8080/rest/' expor ...

  6. dubbo的服务consumer与provider使用的api版本不一致,是否有影响

    dubbo的服务consumer与provider使用的api版本不一致,是否有影响 最近新接手一个项目,看到定义的dubbo接口有些很奇葩的设定. 一.消费端 与 服务端 调用的接口中的数据包装类型 ...

  7. POJ 2096 Collecting Bugs (概率DP,求期望)

    Ivan is fond of collecting. Unlike other people who collect post stamps, coins or other material stu ...

  8. 我的第一个Maven Helloworld

    使用MAVEN创建项目可以有两种方式进行创建,第一种,使用mvn命令创建Maven项目,第二种,使用eclipse创建Maven项目. 在创建Maven项目之前,我们需要安装maven,并和配置JDK ...

  9. Vue中封装axios

    参考: https://www.jianshu.com/p/7a9fbcbb1114 https://www.cnblogs.com/dreamcc/p/10752604.html 一.安装axios ...

  10. MariaDB 安装配置记录

    1.集群搭建记录 iptables --append INPUT --protocol tcp \ --source 192.168.126.129 --jump ACCEPT iptables -- ...