好题。果然好题,经典了。

列一个计划,清明前做好状压DP。之后就刷剩下的MULTI。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
const int Status=(1<<8); int dp[2][11][Status][Status]; //滚动数组实现。dp[i][j][k][l],其中表示当前状态i(权且认为是i行),推出下一个状态next,i状态以前总共使用了
//j个骑士,ki-1行放骑士的状态,l是i行的状态,这时的放置方法数。答案DP就行。
bool crashpt[Status][Status]; //当前行状态与上两行的状态是否有不相容
bool crashpo[Status][Status]; //当前行(要推出的行)与上一行状是否有冲突
int total[Status]; //每种状态会用了多少个骑士。
int G[10],n; //G[i]表示第i行可放骑士的位置的情况,压 缩。
char str[10]; void predo(){
memset(crashpt,false,sizeof(crashpt));
memset(crashpo,false,sizeof(crashpo));
memset(total,0,sizeof(total));
for(int i=0;i<Status;i++){
for(int j=0;j<8;j++){
if(i&(1<<j)) total[i]++;
}
for(int j=0;j<Status;j++){
if((j&(i>>2))||(i&(j>>2))) crashpo[i][j]=true;
if((j&(i>>1))||(i&(j>>1))) crashpt[i][j]=true;
}
}
} void slove(){
int cur=0,next=1;
memset(dp[0],0,sizeof(dp[0]));
dp[cur][0][0][0]=1;
for(int i=0;i<8;i++){
for(int j=0;j<=n;j++){
for(int t=0;t<Status;t++){
for(int o=0;o<Status;o++){
if(!dp[cur][j][t][o]) continue;
for(int now=0;now<Status;now++){
if(j+total[now]>n) continue;
if((now&G[i+1])!=now) continue;
if(crashpt[now][t]||crashpo[now][o]) continue;
dp[next][j+total[now]][o][now]+=dp[cur][j][t][o];
}
}
}
}
memset(dp[cur],0,sizeof(dp[cur]));
swap(cur,next);
}
int ans=0;
for(int i=0;i<Status;i++){
for(int j=0;j<Status;j++)
ans+=dp[cur][n][i][j];
}
printf("%d\n",ans);
} int main(){
int T;
scanf("%d",&T);
predo();
while(T--){
scanf("%d",&n);
memset(G,0,sizeof(G));
for(int i=1;i<=8;i++){
scanf("%s",str);
for(int j=0;j<8;j++){
G[i]<<=1;
if(str[j]=='.') G[i]|=1;
}
}
slove();
}
return 0;
}

  

HDU 4529的更多相关文章

  1. HDU 4529 郑厂长系列故事——N骑士问题 状压dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4529 郑厂长系列故事--N骑士问题 Time Limit: 6000/3000 MS (Java/O ...

  2. hdu 4529 Double Dealing (置换群)

    # include <stdio.h> # include <algorithm> # include <string.h> using namespace std ...

  3. HDU 4529 状压dp

    郑厂长系列故事——N骑士问题 Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)To ...

  4. 【转载】ACM总结——dp专辑

    感谢博主——      http://blog.csdn.net/cc_again?viewmode=list       ----------  Accagain  2014年5月15日 动态规划一 ...

  5. 【DP专辑】ACM动态规划总结

    转载请注明出处,谢谢.   http://blog.csdn.net/cc_again?viewmode=list          ----------  Accagain  2014年5月15日 ...

  6. dp专题训练

    ****************************************************************************************** 动态规划 专题训练 ...

  7. 【DP专辑】ACM动态规划总结(转)

    http://blog.csdn.net/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强, ...

  8. dp有哪些种类

    dp有哪些种类 一.总结 一句话总结: 二.dp动态规划分类详解 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强,主要考察思维能力.建模抽象能力.灵活度. * ...

  9. (转)dp动态规划分类详解

    dp动态规划分类详解 转自:http://blog.csdn.NET/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间 ...

随机推荐

  1. ARM VM安装Linux Diagnostic 2.3扩展

    目前创建的Azure Linux虚拟机默认安装的是LAD 3.0,如果客户有特殊需求,可以通过如下方法安装LAD 2.3 1.在Azure Portal卸载LAD 3.0 2.使用Azure Powe ...

  2. Akka源码分析-Remote-网络链接

    上一篇博客中,我们分析了Akka remote模式下消息发送的过程,但细心的读者一定发现没有介绍网络相关初始化.创建链接.释放链接的过程,本文就介绍一下相关的内容. 网络初始化就离不开ActorSys ...

  3. go 成长路上的坑(1)

    一.先来看一段代码 package main import "fmt" type X struct{} func (x *X) test(){ println("h1&q ...

  4. DFS知识点

    2019-06-01 11:14:34 加油,坚持!!! 1.  2. 3.

  5. RabbitMQ死循环-延长ACK时间

    一.应用背景 今天做一个需求,要将RabbitMQ中的任务取出并执行,为防止任务执行期间出错,设置NO_ACK=FALSE标志,这样.一旦任务没有应答的话,相应的任务就会被RabbitMQ自动Re-Q ...

  6. win10 激活方法 (各版本)

    很多人都在找Win10专业版永久密钥,其实win10激活码不管版本新旧都是通用的,也就是说一个win10专业版key,可以同时激活windows10专业版1809.1803.1709.1703.160 ...

  7. 修路方案 Kruskal 之 次小生成树

    次小生成树 : Kruskal 是先求出来  最小生成树 , 并且记录下来所用到的的边 , 然后再求每次都 去掉最小生成树中的一个边 , 这样求最小生成树 , 然后看能不能得到 和原来最小生成树一样的 ...

  8. [python] ThreadPoolExecutor线程池

    初识 Python中已经有了threading模块,为什么还需要线程池呢,线程池又是什么东西呢?在介绍线程同步的信号量机制的时候,举得例子是爬虫的例子,需要控制同时爬取的线程数,例子中创建了20个线程 ...

  9. 332 Reconstruct Itinerary 重建行程单

    Given a list of airline tickets represented by pairs of departure and arrival airports [from, to], r ...

  10. Objective-C——Runtime理解

    动态语言 OC是一门不折不扣的动态语言,所以它的很多机制都是动态运行时决定的.这点和C语言不一样,C语言是静态绑定,也就是编译后所有的一切都已经决定了.这一点和C语言的函数指针有些类似,很多时候函数指 ...