[SCOI2005]互不侵犯 (状压$dp$)
Posted kv-stalin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[SCOI2005]互不侵犯 (状压$dp$)相关的知识,希望对你有一定的参考价值。
题目链接
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;
}
以上是关于[SCOI2005]互不侵犯 (状压$dp$)的主要内容,如果未能解决你的问题,请参考以下文章
BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]
BZOJ 1087 [SCOI2005]互不侵犯King (状压DP)