社区讨论

求助

灌水区参与者 3已保存回复 3

讨论操作

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

当前回复
3 条
当前快照
1 份
快照标识符
@m0dk0vzr
此快照首次捕获于
2024/08/28 15:48
2 年前
此快照最后确认于
2025/11/04 22:11
4 个月前
查看原帖
「一本通 5.4 练习 1」涂抹果酱
CPP
#include<bits/stdc++.h>
using namespace std;
int n,m,k,can[10005],t,dp[10005][350],a[10],sum,ans1,ans2,mod=1000000;
bool check(int x,int y){
	int t=m; 
	while(t--){
		if(x%3==y%3) return 0;
		x/=3;
		y/=3;
	}
	return 1;
}
void dfs(int x,int cnt){
	if(x==m+1){
		can[++t]=cnt;
		if(check(cnt,sum)) dp[k-1][cnt]=dp[k+1][cnt]=1; 
		return;
	}
	for(int i=0;i<3;i++){
		if(i==cnt%3&&x>1) continue;
		dfs(x+1,(cnt<<1)+cnt+i);
	}
}

int main(){
	cin>>n>>m>>k;
	for(int i=1;i<=m;i++){
		cin>>a[i];
		if(a[i]==a[i-1]){
			cout<<0;
			return 0;
		}
		sum=(sum<<1)+sum+a[i]-1;
	}
	dfs(1,0);
	for(int i=k-2;i>=1;i--){
		for(int jj=1;jj<=t;jj++){
			int j=can[jj];
			for(int ll=1;ll<=t;ll++){
				int l=can[ll];
				if(check(j,l)){
					dp[i][l]=(dp[i][l]+dp[i+1][j])%mod;
				}
			}
		}
	}
	for(int i=k+2;i<=n;i++){
		for(int jj=1;jj<=t;jj++){
			int j=can[jj];
			for(int ll=1;ll<=t;ll++){
				int l=can[ll];
				if(check(j,l)){
					dp[i][l]=(dp[i][l]+dp[i-1][j])%mod;
				}
			}
		}
	}
	for(int i=1;i<=t;i++){
		int x=can[i];
		ans1=(ans1+dp[1][x])%mod;
		ans2=(ans2+dp[n][x])%mod;
	}
	if(k==1) ans1=1;
	if(k==n) ans2=1;
	cout<<(ans1*ans2)%mod;
}
80分,可能有哪些问题?

回复

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

正在加载回复...