社区讨论

诡异代码求条

P1896[SCOI2005] 互不侵犯参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@mm2vvx38
此快照首次捕获于
2026/02/26 11:08
2 周前
此快照最后确认于
2026/02/26 11:40
2 周前
查看原帖
CPP
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,k,ex[1500],cnt[1500],num;
int f[11][110][1500];
signed main()
{
	cin>>n>>k;
	for(int i=0;i<(1<<n);++i)
	{
		int tot=0,t=i;
		while(t!=0)
		{
			tot+=t&1;
			t>>=1;
		}
//		cout<<(i&(i<<1))<<" "<<(i&(i>>1))<<" "<<tot<<" "<<i<<" "<<k<<" "<<num<<"\n";
		if((i&(i<<1))==0&&(i&(i>>1))==0) ex[++num]=i,cnt[num]=tot,f[1][tot][i]=1;
	}
	for(int i=2;i<=n;++i)
	{
		for(int j=1;j<=num;++j)
		{
			int now=ex[j];
			for(int kk=1;kk<=num;++kk)
			{
				int last=ex[kk];
				if((now&last)==0&&(now&(last<<1))==0&&(now&(last>>1))==0) 
				{
					for(int l=0;l<=k;++l)
					if(l-cnt[now]>=0) f[i][l][now]+=f[i-1][l-cnt[now]][last],cout<<f[i][l][now]<<"   "<<i<<"  "<<l<<" ";
					cout<<"\n";
				}
			}
		}
	}
	int ans=0;
	for(int i=1;i<=num;++i) ans+=f[n][k][ex[i]];
	cout<<ans<<"\n";
	return 0;
}
样例一直输出13
三个魔丸调了半天没调对

回复

0 条回复,欢迎继续交流。

正在加载回复...