[SCOI2005]互不侵犯 (状压$dp$)
2024-09-04 11:40:20
题目链接
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;
}
最新文章
- ABP理论学习之通知系统
- .dwg(sw)-exb
- /etc/rc.d/rc与/etc/rc.d/init.d的关系
- GithubPage 的简单使用
- C语言 断言 总结
- java 级联删除文件夹下的所有文件
- C++函数内存占用
- apache开源项目--gora
- 深度解析Linux通过日志反查入侵
- Java中多态的理解
- SaltStack 架构自动部署 03
- 在python后台如何将客户端提交的form表单数据提取出来?
- GIS之家小专栏
- 学JAVA第十五天,方法重载及构造方法进一步了解
- python 循环结构 while for...in
- Django Rest Framework之权限
- jmeter一些插件下载网址
- .NET 常用加密、解密&; 数字签名算法
- mysql查询表基本操作
- c语言个人财务管理系统