首页 > 代码库 > AC日记——[SCOI2008] 着色方案 bzoj 1079
AC日记——[SCOI2008] 着色方案 bzoj 1079
1079
思路:
dp;
我们如果dp方程为15维,每维记录颜色还有多少种;
不仅tle,mle,它还re;
所以,我们压缩一下dp方程;
方程有6维,第i维记录有多少种颜色还剩下i次;
最后还要记录上次使用是第几维;
来,上代码:
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>using namespace std;#define ll long long#define mod 1000000007ll n,m[6],sum,ai[6],dp[16][16][16][16][16][6];bool if_[16][16][16][16][16][6];ll dfs(ll a,ll b,ll c,ll d,ll e,ll f){ if(a<0||b<0||c<0||d<0||e<0) return 0; if(a+b+c+d+e>sum) return 0; if(a>m[5]||b>m[4]||c>m[3]||d>m[2]||e>m[1]) return 0; if(if_[a][b][c][d][e][f]) return dp[a][b][c][d][e][f]; if_[a][b][c][d][e][f]=true; ll now=0; if(f==1) { now+=dfs(a,b,c,d,e+1,0)*(e+1); now+=dfs(a,b,c,d,e+1,1)*(e+1); now+=dfs(a,b,c,d,e+1,2)*e; now+=dfs(a,b,c,d,e+1,3)*(e+1); now+=dfs(a,b,c,d,e+1,4)*(e+1); now+=dfs(a,b,c,d,e+1,5)*(e+1); } else if(f==2) { now+=dfs(a,b,c,d+1,e-1,0)*(d+1); now+=dfs(a,b,c,d+1,e-1,1)*(d+1); now+=dfs(a,b,c,d+1,e-1,2)*(d+1); now+=dfs(a,b,c,d+1,e-1,3)*d; now+=dfs(a,b,c,d+1,e-1,4)*(d+1); now+=dfs(a,b,c,d+1,e-1,5)*(d+1); } else if(f==3) { now+=dfs(a,b,c+1,d-1,e,0)*(c+1); now+=dfs(a,b,c+1,d-1,e,1)*(c+1); now+=dfs(a,b,c+1,d-1,e,2)*(c+1); now+=dfs(a,b,c+1,d-1,e,3)*(c+1); now+=dfs(a,b,c+1,d-1,e,4)*c; now+=dfs(a,b,c+1,d-1,e,5)*(c+1); } else if(f==4) { now+=dfs(a,b+1,c-1,d,e,0)*(b+1); now+=dfs(a,b+1,c-1,d,e,1)*(b+1); now+=dfs(a,b+1,c-1,d,e,2)*(b+1); now+=dfs(a,b+1,c-1,d,e,3)*(b+1); now+=dfs(a,b+1,c-1,d,e,4)*(b+1); now+=dfs(a,b+1,c-1,d,e,5)*b; } else if(f==5) { now+=dfs(a+1,b-1,c,d,e,0)*(a+1); now+=dfs(a+1,b-1,c,d,e,1)*(a+1); now+=dfs(a+1,b-1,c,d,e,2)*(a+1); now+=dfs(a+1,b-1,c,d,e,3)*(a+1); now+=dfs(a+1,b-1,c,d,e,4)*(a+1); now+=dfs(a+1,b-1,c,d,e,5)*(a+1); } now%=mod; dp[a][b][c][d][e][f]=now;// printf("%d %d %d %d %d %d %lld\n",a,b,c,d,e,f,now); return now;}int main(){// freopen("color.in","r",stdin);// freopen("color.out","w",stdout); cin>>n;ll pos; for(ll i=1;i<=n;i++) { cin>>pos; ai[pos]++; } for(ll i=1;i<=5;i++) { for(ll j=i;j<=5;j++) m[i]+=ai[j]; sum+=ai[i]; } dp[ai[5]][ai[4]][ai[3]][ai[2]][ai[1]][0]=1; if_[ai[5]][ai[4]][ai[3]][ai[2]][ai[1]][0]=true; cout<<dfs(0,0,0,0,0,1); return 0;}
AC日记——[SCOI2008] 着色方案 bzoj 1079
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。