社区讨论
萌新求助!调了好久,样例都没过!
P1896[SCOI2005] 互不侵犯参与者 2已保存回复 1
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 1 条
- 当前快照
- 1 份
- 快照标识符
- @lo8q8a1j
- 此快照首次捕获于
- 2023/10/27 22:46 2 年前
- 此快照最后确认于
- 2023/10/27 22:46 2 年前
CPP
#include<bits/stdc++.h>
using namespace std;
int dp[12][84][1024];
int num[1024];
int getsum(int x){
int tot=0;
while(x>0){
tot+=x&1;
x<<=1;
}
return tot;
}
int main(){
int n,p;
cin>>n>>p;
for(int i=0;i<(1<<n);i++) num[i]=getsum(i);
for(int i=0;i<(1<<n);i++) if((i&(i<<1))==0) dp[1][num[i]][i]=1;
for(int i=2;i<=n;i++){
for(int j=0;j<(1<<n);j++){
for(int sum=0;sum+num[j]<=n*n;sum++)
for(int k=0;k<(1<<n);k++)
if(!(j&(j<<1)) and !(k&(k<<1)) and !(j&k) and !(j&(k<<1)) and !(k&(j<<1)))
dp[i][sum+num[j]][j]+=dp[i-1][sum][k];
}
}
int ans=0;
for(int i=0;i<(1<<n);i++) ans+=dp[n][p][i];
cout<<ans<<endl;
return 0;
}
回复
共 1 条回复,欢迎继续交流。
正在加载回复...