题目:
分析:状态压缩就一句话:把状态用二进制转换成一个数。
代码:
#include<bits/stdc++.h>
using namespace std;
int m,n;
long long A[10][160][160];
int A1[160];
int A2[160];
int cnt=1;
void init()
{
for(int i=0;i<(1<<m);i++)
{
if(i&(i<<1)) continue;
int sum=0;
for(int j=0;j<m;++j) if(i&(1<<j)) ++sum;
A1[cnt]=i;
A2[cnt]=sum;
cnt++;
}
}
int main()
{
cin>>m>>n;
init();
A[0][1][0]=1;
for(int i=1;i<=m;i++)
{
for(int j=1;j<cnt;j++)
{
for(int k=0;k<=n;k++)
{
if(k<A2[j]) continue;
for(int t=1;t<cnt;t++)
if(!(A1[t]&A1[j])&&!(A1[t]&(A1[j]<<1))&&!(A1[t]&(A1[j]>>1)))
A[i][j][k]+=A[i-1][t][k-A2[j]];
}
}
}
long long cc=0;
for(int i=1;i<cnt;++i)
cc+=A[m][i][n];
cout<<cc;
}