题目链接


Solution

状压 \(dp\) .

\(f[i][j][k]\) 代表前 \(i\) 列中 , 已经安置 \(j\) 位国王,且最后一位状态为 \(k\) .

然后就可以很轻松的转移了...

记忆化搜索还是不够啊... 只能会正向 \(dp\) .

Code

#include<bits/stdc++.h>
#define ll long long
using namespace std; ll f[10][101][1100],n,K;
ll js[1100],sum,ans; int main()
{
cin>>n>>K;
sum=(1<<n)-1; for(ll i=0;i<=sum;i++)
for(ll j=0;j<n;j++)
if(i&(1<<j))js[i]++; for(ll i=0;i<=sum;i++)
if((i<<1&i))continue;
else f[1][js[i]][i]=1; for(ll i=1;i<n;i++)
for(ll j=0;j<=K;j++)
for(ll k=0;k<=sum;k++)
{
if(!f[i][j][k])continue;
for(ll kk=0;kk<=sum;kk++)
{
if((kk<<1&kk))continue;
if((k&kk)||((k>>1)&kk)||((k<<1)&kk))continue;
if(j+js[kk]>K)continue;
f[i+1][j+js[kk]][kk]+=f[i][j][k];
}
}
for(ll i=0;i<=sum;i++)
ans+=f[n][K][i];
cout<<ans<<endl;
}

最新文章

  1. ABP理论学习之通知系统
  2. .dwg(sw)-exb
  3. /etc/rc.d/rc与/etc/rc.d/init.d的关系
  4. GithubPage 的简单使用
  5. C语言 断言 总结
  6. java 级联删除文件夹下的所有文件
  7. C++函数内存占用
  8. apache开源项目--gora
  9. 深度解析Linux通过日志反查入侵
  10. Java中多态的理解
  11. SaltStack 架构自动部署 03
  12. 在python后台如何将客户端提交的form表单数据提取出来?
  13. GIS之家小专栏
  14. 学JAVA第十五天,方法重载及构造方法进一步了解
  15. python 循环结构 while for...in
  16. Django Rest Framework之权限
  17. jmeter一些插件下载网址
  18. .NET 常用加密、解密&amp; 数字签名算法
  19. mysql查询表基本操作
  20. c语言个人财务管理系统

热门文章

  1. docker简介以及优缺点
  2. js 判断function是否存在
  3. cookie操作和代理
  4. ubuntu配置命令
  5. PHP.14-图片处理类
  6. CodeForces 785C Anton and Fairy Tale 二分
  7. HDU 4405 Aeroplane chess(期望dp)
  8. android 文件下载 超简单
  9. http客户端缓存
  10. gulp批量添加版本号