【poj2411】Mondriaan's Dream 状态压缩dp-程序员宅基地

AC传送门:http://vjudge.net/problem/POJ-2411

【题目大意】

有一个W行H列的广场,需要用1*2小砖铺盖,小砖之间互相不能重叠,问有多少种不同的铺法?

【题解】

对于每一行有w个位置,所以每一行都有0~2w-1种状态。

对于当前行的状态s,它是由前一行的状态s’转化过来的,显然,对于该行某个位置j:

如果前一行该位置为0,那么该位置可以竖放 即 0-> 1

如果前一行连续两个位置为0,那么这两个连续位置可以横放 即00-> 00

如果前一行该位置为1,显然该位置不能再放,于是应该把该位置设置为0 ,即1-> 0

/*************
  poj 2411
  by chty
  2016.11.15
*************/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<ctime>
#include<cmath>
#include<algorithm>
using namespace std;
#define FILE "read"
#define up(i,j,n)  for(int i=j;i<=n;i++)
namespace INIT{
	char buf[1<<15],*fs,*ft;
	inline char getc() {return (fs==ft&&(ft=(fs=buf)+fread(buf,1,1<<15,stdin),fs==ft))?0:*fs++;}
	inline int read(){
		int x=0,f=1;  char ch=getc();
		while(!isdigit(ch))  {if(ch=='-')  f=-1;  ch=getc();}
		while(isdigit(ch))  {x=x*10+ch-'0';  ch=getc();}
		return x*f;
	}
}using namespace INIT;
int n,m;
long long f[15][2500];
void dfs(int i,int s1,int s2,int next){
	if(next>m)  return;
	if(next==m)  f[i+1][s2]+=f[i][s1];
	else if((s2&(1<<next))==0){
		dfs(i,s1,s2|(1<<next),next+1);
		if((s2&(1<<(next+1)))==0)  dfs(i,s1,s2,next+2);
	}
	else dfs(i,s1,s2&~(1<<next),next+1);
}
int main(){
	freopen(FILE".in","r",stdin);
	freopen(FILE".out","w",stdout);
	while(~scanf("%d%d",&n,&m)&&n&&m){
		memset(f,0,sizeof(f));  f[1][0]=1;
		up(i,1,n)  up(j,0,(1<<m)-1)  if(f[i][j])  dfs(i,j,j,0);
		printf("%lld\n",f[n+1][0]);
	}
	return 0;
}


转载于:https://www.cnblogs.com/chty/p/6068113.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/anzhi7214/article/details/102106962

智能推荐

解决springboot,单元测试启动ApplicationRunner问题_applicationrunner解决-程序员宅基地

文章浏览阅读1.6k次。在执行单元测试时,ApplicationRunner被意外启动,导致了Netty服务器被初始化,单元测试无法执行的问题。解决方案:通过设置ApplicationRunner对应Bean的Profile解决对应组件添加注解:@Profile("!test")单元测试添加注解:@ActiveProfiles("test")..._applicationrunner解决

Java前景如何,容易找工作嘛_java 岗位找工作容易-程序员宅基地

文章浏览阅读748次。/*文章很长,能看完的少走一个月弯路,绝不抖机灵*/这篇文章是为了介绍自己自学用过的Java视频资料。本套整合教程总共180+G,共450+小时。考虑到绝大部分视频至少要看两遍,而且视频总时长并不代表学习时长,所以零基础初学者总学习时间大约为:600小时视频时长 + 100小时理解 + 100小时练习,至少需要800小时。你可能觉得自己能一天学习8小时,实际上平均下来每天能学4小时都算厉害了。总会有各种原因,比如当天内容太难,公司聚会,要出差等等。如果周末你也是坚持学习,那么最理想状况下,6_java 岗位找工作容易

【顺序表和链表】_什么是顺序表?什么是链表?-程序员宅基地

文章浏览阅读1.5k次,点赞27次,收藏14次。文章目录一:线性表1.1 顺序表1.1.1 接口实现1.2 链表1.2.1 链表与数组的区别1.2.2 结构体的自引用1.2.3 链表的分类一:线性表线性表是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构,常见的线性表有:顺序表,链表,栈,队列,字符串等。线性表在逻辑上是线性结构,也就是说是一条连续的实线,但其实在物理结构上不一定连续,其中线性表在储存的时候,通常以数组和链式结构的形式存储。1.1 顺序表顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性_什么是顺序表?什么是链表?

valine评论系统不能使用_code 403: 访问被api域名白名单拒绝,请检查你的安全域名设置-程序员宅基地

文章浏览阅读2.1k次。一.今天发现 Valine 评论系统不见了,没法使用啦,发现原来是valine里的av -min.js检查不到的原因。官方也给了说法,是因为 leancloud.cn 以及 …lncld.net 域名不能解析了。那我的解决方法是什么呢??首先,我找到了av -min.js和valine.min.js的源码。源码链接如下: av -min.js valine.min.js接下来我们在我们的github.io上/js下新建两个js文件,分别是av -min.js和valine.min.js然_code 403: 访问被api域名白名单拒绝,请检查你的安全域名设置

tp框架文件上传七牛服务器,TP5开发 - 七牛云图片上传方法-程序员宅基地

文章浏览阅读280次。1、config.php配置文件里配置七牛云密钥等里面 secretKey accessKey domain bucket对应换成自己七牛云申请的,步骤:(1)七牛云注册成功后—对象存储申请10G免费空间,(2)右上角个人中头像image.pngimage.png//配置文件return [// 文件上传默认驱动'UPLOAD_DRIVER' => 'Qiniu', //设置七牛上传驱动//..._lkqtp

贪心算法总结_贪心算法如何跳出局部最优 知乎-程序员宅基地

文章浏览阅读788次。目录贪心算法的思想贪心算法的基本要素 最优子结构 贪心选择性质贪心算法与动态规划算法的差异贪心算法的一般理论相关例题 活动安排问题 哈夫曼编码 最小生成树问题贪心算法的思想贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上的局部最优选择。当然,希望贪心算法得到的最终结果也是整体最优的。虽然贪心算法不能对所有问题都得到整体最..._贪心算法如何跳出局部最优 知乎

随便推点

多行业万能预约门店小程序源码系统 带完整的搭建教程以及安装代码包-程序员宅基地

文章浏览阅读472次。小编给大家分享一款多行业万能预约门店小程序源码系统。该系统不仅具备高度的可定制性,还提供了丰富的功能模块,能够轻松应对不同行业的预约需求。:该系统支持多行业预约需求,无论是美容美发、餐饮娱乐还是医疗健身等行业,都能找到适合的预约模板和功能模块。:该系统提供了完整的搭建教程和安装代码包,用户只需按照教程操作,即可轻松完成小程序的搭建和部署。:系统提供了丰富的数据分析和统计功能,可以帮助商家了解预约情况、客户分布等信息,为门店运营提供有力支持。同时,还支持预约提醒功能,确保客户能够按时到店,提高预约的准确率。

解决antd的select下拉框因为数据量太大造成卡顿的问题_select 数据量太大-程序员宅基地

文章浏览阅读2.1w次,点赞23次,收藏42次。相信用过antd的同学基本都用过select下拉框了,这个组件数据量少的时候很好用,但是当数据量大的时候,比如大几百条上千条甚至是几千条的时候就感觉一点都不好用了,卡的我怀疑人生,一点用户体验都没有了。当然这不是我想去优化它的动力,主要是公司业务人员和后端的同事也无法忍受,于是我只能屈从于他们的淫威。。。。想要优化肯定要知道为什么会卡,初步判断就是数据量过大导致渲染option组件的时间过长导致卡..._select 数据量太大

使用MQTT.fx与百度天工物接入平台实现嵌入式设备的对接_百度天工mqtt还能用嘛-程序员宅基地

文章浏览阅读120次。通过本文的介绍,我们了解了如何使用MQTT.fx与百度天工物接入平台对接嵌入式设备。首先,我们注册了百度天工账号并创建了物接入应用;最后,我们通过订阅和发布消息的方式实现了与百度天工物接入平台的数据交互。在这个背景下,百度推出了天工物接入平台,为开发者提供了简单、高效的物联网设备连接方案。MQTT.fx是一款开源的MQTT客户端工具,它支持多种操作系统,并提供了直观的用户界面,方便开发者进行MQTT消息的订阅和发布操作。百度天工物接入平台是百度基于物联网技术推出的一款用于连接和管理物联网设备的平台。_百度天工mqtt还能用嘛

【深度学习】Normalizing flow原理推导+Pytorch实现-程序员宅基地

文章浏览阅读1.4k次,点赞33次,收藏31次。1、前言Normalizingflow\boxed{Normalizing \hspace{0.1cm} flow}Normalizingflow​,流模型,一种能够与目前流行的生成模型——GAN、VAE\boxed{\mathbf{GAN、VAE}}GAN、VAE​相媲美的模型。其也是一个生成模型,可是它的思路和另外两个的迂回策略却很大不同。本文我们就简单来介绍一个这个模型吧2、引入在生成模型中,我们的目的就是计算出数据x的概率分布。然而,数据的分布总是千奇百怪的。其无法被定义,无法被观测,无法被_normalizing flow

系统架构设计师之备考攻略(2024年修订版)——一篇就够_系统架构师复习攻略-程序员宅基地

文章浏览阅读1.8w次,点赞34次,收藏141次。2020年9月至11月初,本人用两个月的时间来备考【系统架构设计师】这一科目,最终以综合题 59/75 案例 57/75 论文 53/75 的成绩顺利通过。备考过程中,发现由于这个考试比较冷门,遇到了【学习资料少】、【备考方向不明确】等问题,走了不少弯路。因此想分享一下备考中的干货,帮助想要备考【系统架构设计师】的同学。_系统架构师复习攻略

领域驱动设计(Domain-Driven Design DDD)——通过重构找到深层次模型2-程序员宅基地

文章浏览阅读9.1k次,点赞21次,收藏26次。深层模型和柔性设计并非唾手可得。想要取得进展,必须学习大量领域知识并进行充分的讨论,还需要经历大量的尝试和失败。在实际的研究领域问题实践时,有一些成熟的模式可以供我们借鉴和套用。这样我们可以从这个起点来重构和试验,虽然它们不是现成的解决方案。