牧场的安排

内存限制:512 MiB

时间限制:1000 ms

原题来自:USACO 2006 Nov. Gold

Farmer John 新买了一块长方形的牧场,这块牧场被划分成 MMM 行 NNN 列 (1≤M≤12;1≤N≤12),每一格都是一块正方形的土地。FJ 打算在牧场上的某几格土地里种上美味的草,供他的奶牛们享用。遗憾的是,有些土地相当的贫瘠,不能用来放牧。并且,奶牛们喜欢独占一块草地,于是 FJ 不会选择两块相邻的土地,即:没有哪两块草地有公共边。当然,FJ 还没有决定在哪些土地上种草。

作为一个好奇的农场主,FJ 想知道,如果不考虑草地的总块数,那么,一共有多少种种植方案可供他选择。当然,把新的牧场荒废,不在任何土地上种草,也算一种方案。请你帮 FJ 算一下这个总方案数。

输入格式

第 111 行:两个正整数 MMM 和 NNN,用空格隔开;
第 222 到 M+1M+1M+1 行:每行包含 NNN 个用空格隔开的整数,描述了每块土地的状态。输入的第 i+1i+1i+1 行描述了第 iii 行的土地。所有整数均为 000 或 111,111 表示这块土地足够肥沃,000 则表示这块地上不适合种草。

输出格式

第 111 行:输出一个整数,即牧场分配总方案数除以 10810^810​8​​ 的余数。

样例

样例输入

2 3
1 1 1
0 1 0

样例输出

9
--------------------------------------------------------------------------------------------------
状态压缩动态规划

首先处理出所有行的复合要求的养牛的状态,
(s&cd[i])==s && (s&(s<<1))==0,也就是当前养牛的场地都在有草的地方且养牛的地点不相邻

让后状压动归,f[i][s]表示到第i行,且第i行的状态为s的情况下有多少种方案。

f[i][s]+=f[i-1][ss],条件s和ss都是对应的行内的合法状态,且两者之间的关系合法,也就是s&ss==0
--------------------------------------------------------------------------------------------------

 1 #include<bits/stdc++.h>
2 using namespace std;
3 typedef long long ll;
4 int n,m;
5 vector<int>st[14];
6 int cd[14];
7 ll f[14][(1<<12)+5];
8
9 void getst()
10 {
11 st[0].push_back(0);
12 for(int i=1;i<=n;++i)
13 {
14 for(int s=0;s<(1<<m);s++)
15 {
16 if((s&cd[i])==s && (s&(s<<1))==0)st[i].push_back(s);
17 }
18 }
19 }
20 void dp()
21 {
22 f[0][0]=1;
23 for(int i=1;i<=n;++i)
24 {
25 for(int s=0;s<st[i].size();++s)
26 {
27 for(int ss=0;ss<st[i-1].size();ss++)
28 if((st[i][s]&st[i-1][ss])==0)
29 f[i][st[i][s]]=(f[i][st[i][s]]+f[i-1][st[i-1][ss]])%100000000;
30 }
31 }
32 }
33 int main()
34 {
35 scanf("%d%d",&n,&m);
36 for(int i=1;i<=n;++i)
37 {
38 int tp;
39 for(int j=0;j<m;++j)
40 {
41 scanf("%d",&tp);
42 cd[i]=(cd[i]<<1)|tp;
43 }
44 }
45 getst();
46 dp();
47 long long ans=0;
48 for(int s=0;s<st[n].size();++s)ans+=f[n][st[n][s]],ans%=100000000;
49 cout<<ans;
50 return 0;
51 }

loj10171的更多相关文章

随机推荐

  1. flowable流程启动时监听器

    一.核心配置类 package com.magus.project.flow.config; import com.google.common.collect.Maps; import com.mag ...

  2. Qt学习笔记-支持Gif动画显示

    写QT程序时遇到个问题,本机编译完成的应用程序的Gif正常显示,但移到开发板上,gif无法显示,最后发现是其实是插件的关系. 在编译安装的路径中有一个 plugins/imageformats 里面是 ...

  3. JDBC删除

    1 if(conn != null){ 2 String temps="3"; 3 conn.setAutoCommit(false); 4 PreparedStatement p ...

  4. canvas--总结二

    canvas图形绘制 矩形绘制 rect(x,y,w,h)  没有独立路径 strokeRect(x,y,w,h) 有独立路径,不影响别的绘制 fillRect(x,y,w,h) 有独立路径,不影响别 ...

  5. 2020 年度编程语言排行榜出炉!C 语言称霸,Java 遭遇滑铁卢…….

    最近,TIOBE 发布了过去一年的编程语言排行榜: 数据来源TIOBE: https://www.tiobe.com/tiobe-index/ TIOBE介绍: TIOBE编程语言索引是编程语言流行程 ...

  6. git-廖雪峰版教程学习笔记

  7. CentOS 7 网卡注释

    TYPE=Ethernet # 网络类型为:EthernetPROXY_METHOD=none # 代理方式:关闭状态BROWSER_ONLY=no # 只是浏览器:否BOOTPROTO=static ...

  8. Java并发编程实战(3)- 互斥锁

    我们在这篇文章中主要讨论如何使用互斥锁来解决并发编程中的原子性问题. 目录 概述 互斥锁模型 互斥锁简易模型 互斥锁改进模型 Java世界中的互斥锁 synchronized中的锁和锁对象 synch ...

  9. LeetCode733 图像渲染

    有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 0 到 65535 之间. 给你一个坐标 (sr, sc) 表示图像渲染开始的像素值(行 ,列)和一个新的颜色值 newCol ...

  10. windows下部署Grafana +prometheus平台监控

      1.Prometheus简介 Prometheus基于Golang编写,编译后的软件包,不依赖于任何的第三方依赖.用户只需要下载对应平台包,解压并且添加基本的配置即可正常启Prometheus S ...