思路:

每个槽有4种深度,一共有2^4种状态。然后开4维来保存每一次的状态:dp[ 第几个槽 ][ 当前状态 ][ 末尾深度 ][ 是否符合要求 ]。

代码:

#include<cstdio>
#include<map>
#include<set>
#include<queue>
#include<cstring>
#include<string>
#include<cmath>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define ll long long
const int N = 500+5;
const int INF = 0x3f3f3f3f;
using namespace std;
ll dp[32][1<<4+5][4][2]; //第几个槽,槽的状态,最后一个槽的深度,是否已经符合要求
int num[20];
int main(){
memset(dp,0,sizeof(dp));
memset(num,0,sizeof(num));
for(int i = 0;i < 16;i++){
for(int j = 0;j < 4;j++){
if(i & (1<<j)) num[i]++; //计算满足深度大于等于3
}
}
dp[1][1][0][0] = dp[1][2][1][0] = dp[1][4][2][0] = dp[1][8][3][0] = 1;
for(int i = 2;i <= 31;i++){ //第几个槽
for(int j = 0;j < 16;j++){ //上一个槽状态
for(int k = 0;k < 4;k++){ //上一个槽末尾
for(int l = 0;l < 4;l++){ //这个槽末尾
int sta = j | (1<<l); //当前状态
dp[i][sta][l][1] += dp[i - 1][j][k][1];
if(k - l == 3 || l - k == 3){
dp[i][sta][l][1] += dp[i - 1][j][k][0];
}
else{
dp[i][sta][l][0] += dp[i - 1][j][k][0];
}
}
}
}
}
ll ans;
for(int i = 2;i <= 31;i++){
ans = 0;
for(int j = 0;j < 16;j++){
if(num[j] >= 3){
for(int k = 0;k < 4;k++){
ans += dp[i][j][k][1];
}
}
}
printf("N=%d: %lld\n",i,ans);
}
return 0;
}

最新文章

  1. SSH基于Hibernate eventListener 事件侦听器的操作日志自动保存到数据库
  2. SparkSql 不支持Date Format (支持Timestamp)
  3. 【openGL】画圆
  4. oracle视图
  5. iOS开发网络篇—HTTP协议
  6. Send an email with format which is stored in a word document
  7. 制作第三方SDK静态库、.framework
  8. centos 6.3安装mono和monoDevelop过程
  9. hibernate缓存技术
  10. DataGrid缓冲加载数据
  11. Hive基础(2)---(启动HiveServer2)Hive严格模式
  12. NOI2009 植物大战僵尸
  13. C# 断言 Assert
  14. 在SpringBoot中添加Redis
  15. 笔记:yum和apt-get的区别
  16. Spring web.xml中的配置
  17. 23种设计模式之装饰模式(Decorator)
  18. UIKeyboardTypeNumberPad 数字键盘添加完成按钮
  19. double、float等多字节数据处理
  20. Python精要参考(第二版)

热门文章

  1. SenchaTouch学习博客
  2. Resin任意文件读取漏洞
  3. WannaCry应急排查思路
  4. elk日志分析与发掘深入分析
  5. struts2的占位符*在action中的配置方法
  6. Swift - 获取当前系统时间
  7. 【转载】网络安全---Strurts2漏洞介绍
  8. poj3764 The XOR Longest Path【dfs】【Trie树】
  9. Golang OOP、继承、组合、接口
  10. 探究 Oracle 高水位对数据库性能影响