ZCC loves cube(cube)
题目描述
调戏完了狗,ZCC开始玩起了积木。ZCC的面前有一块n*n的棋盘,他要用这些1*1*1的积木在棋盘上搭出一个宏伟的建筑。积木有三种颜色,ZCC认为一个建筑要被称为宏伟的应该满足能从正面看到的每一个积木都是同一种颜色。现在,ZCC想要知道他能用他拥有的积木搭出多少种宏伟的建筑。当然,为了让建筑足够大,ZCC需要用完他所有的积木。两个建筑被称为不同的当且仅当两个建筑形状不同或者存在一块相同位置不同颜色的积木。
输入
包含四个数n,r,g,b 。表示棋盘大小,红色积木个数,绿色积木个数,蓝色积木个数。
输出
包含一个数,表示方案数,对10^9+7取模。
数据规模与约定
对于10%的数据,n,r≤40 ,g,b=0
对于另外20%的数据,n,r,g,b≤4
对于100% 的数据,n,r,g,b≤30
solution
计数类问题,考虑dp
由于每一列互不影响,我们分开做。
先考虑一列,不考虑颜色
f[i][j][k] 表示前i位,之前最大值为j,放k个木块的方案数
再令g[i][j][k]表示前i列用了k块,主视图面积为j的方案数
g[i][j][k]=g[i-1][j-x][k-y]*f[n][x][y]
然后根据面积填颜色
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
#define mod 1000000007
using namespace std;
int n,a,b,c,S,M,tot;
ll f[45][45][166],g[45][125][125],ans,tmp;
ll h[80005],ny[80005];
ll F(ll a,int num){
ll cnt=1;
while(num){
if(num&1)cnt=cnt*a;
a=a*a%mod;cnt%=mod;num>>=1;
}
return cnt;
}
void getC(){
int o=n*n*n;h[0]=1;
for(int i=1;i<=o;i++)h[i]=h[i-1]*i%mod;
ny[o]=F(h[o],mod-2);
for(int i=o-1;i>=0;i--)ny[i]=ny[i+1]*(i+1)%mod;
}
ll C(int N,int M){
return (h[N]*ny[M]%mod)*ny[N-M]%mod;
}
int main()
{
cin>>n>>a>>b>>c;S=a+b+c;M=max(a,max(b,c));
f[0][0][0]=1;
for(int i=1;i<=n;i++){
f[i][0][0]=1;
for(int j=1;j<=M;j++){//M
for(int k=j;k<=S;k++){
for(int x=0;x<=j;x++)
f[i][j][k]=(f[i][j][k]+f[i-1][j][k-x])%mod;
for(int x=0;x<j;x++)
f[i][j][k]=(f[i][j][k]+f[i-1][x][k-j])%mod;
//cout<<"i "<<i<<' '<<"j "<<j<<' '<<"k "<<k<<' '<<f[i][j][k]<<endl;
}
}
}
//
g[0][0][0]=1;
for(int i=1;i<=n;i++){
g[i][0][0]=1;
for(int j=1;j<=S;j++){
for(int k=j;k<=S;k++){
for(int x=0;x<=j;x++)
for(int y=x;y<=k;y++){
g[i][j][k]=g[i][j][k]+g[i-1][j-x][k-y]*f[n][x][y]%mod;
g[i][j][k]%=mod;
}//cout<<"i "<<i<<' '<<"j "<<j<<' '<<"k "<<k<<' '<<g[i][j][k]<<endl;
}
}
}
//for(int i=0;i<=S;i++)cout<<g[n][i][S]<<endl;
getC();
for(int i=1;i<=S;i++){
if(a>=i){
int ns=S-i;
ll tmp=g[n][i][S];
tmp=tmp*C(ns,b)%mod*C(ns-b,c)%mod;
ans=(ans+tmp)%mod;
}
if(b>=i){
int ns=S-i;
ll tmp=g[n][i][S];
tmp=tmp*C(ns,a)%mod*C(ns-a,c)%mod;
ans=(ans+tmp)%mod;
}
if(c>=i){
int ns=S-i;
ll tmp=g[n][i][S];
tmp=tmp*C(ns,a)%mod*C(ns-a,b)%mod;
ans=(ans+tmp)%mod;
}
}
cout<<ans<<endl;
//cout<<ans<<endl;
return 0;
}
ZCC loves cube(cube)的更多相关文章
- HDU 4882 ZCC Loves Codefires (贪心)
ZCC Loves Codefires 题目链接: http://acm.hust.edu.cn/vjudge/contest/121349#problem/B Description Though ...
- HDU 4873 ZCC Loves Intersection(可能性)
HDU 4873 ZCC Loves Intersection pid=4873" target="_blank" style="">题目链接 ...
- 2014多校第二场1011 || HDU 4882 ZCC Loves Codefires (贪心)
题目链接 题意 : 给出n个问题,每个问题有两个参数,一个ei(所要耗费的时间),一个ki(能得到的score).每道问题需要耗费:(当前耗费的时间)*ki,问怎样组合问题的处理顺序可以使得耗费达到最 ...
- hdu 4882 ZCC Loves Codefires(贪心)
# include<stdio.h> # include <algorithm> # include <string.h> using namespace std; ...
- ZOJ 2477 Magic Cube(魔方)
ZOJ 2477 Magic Cube(魔方) Time Limit: 2 Seconds Memory Limit: 65536 KB This is a very popular gam ...
- 【Luogu3602】Koishi Loves Segments(贪心)
[Luogu3602]Koishi Loves Segments(贪心) 题面 洛谷 题解 离散区间之后把所有的线段挂在左端点上,从左往右扫一遍. 对于当前点的限制如果不满足显然会删掉右端点最靠右的那 ...
- PLSQL_基础系列02_分组函数GROUP BY / ROLLUP / CUBE(案例)
2014-11-30 Created By BaoXinjian
- hdu 4882 ZCC Loves Codefires(数学题+贪心)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4882 ------------------------------------------------ ...
- HDU 4876 ZCC loves cards(暴力剪枝)
HDU 4876 ZCC loves cards 题目链接 题意:给定一些卡片,每一个卡片上有数字,如今选k个卡片,绕成一个环,每次能够再这个环上连续选1 - k张卡片,得到他们的异或和的数,给定一个 ...
- 【LG 4831】Scarlet loves WenHuaKe(生成函数)
题目链接 一道好题,第一次用生成函数做题.感谢赛珂狼教我这个做法. 首先我们显然可以把题目中的限制转化成一个二分图的模型:左边有$n$个点,右边有$m$个点,如果在棋盘$(i,j)$这个点上放了炮,那 ...
随机推荐
- Hibernate进阶学习3
Hibernate进阶学习3 测试hibernate的多表关联操作(一对多,多对一,多对多) 表之间的关系主要在类与元数据配置文件中体现 package com.hibernate.domain; i ...
- Java执行存储过程
1.JDBC调用存储过程: CallableStatement /** *p是要调用的存储过程的名字,存储过程的4个参数,用4个?号占位符代替 *其余地方写法固定 */ CallableStateme ...
- Python中的文件和目录操作实现
Python中的文件和目录操作实现 对于文件和目录的处理,虽然可以通过操作系统命令来完成,但是Python语言为了便于开发人员以编程的方式处理相关工作,提供了许多处理文件和目录的内置函数.重要的是,这 ...
- 解决win10子系统Ubuntu新装的mysql 不能root登陆方法
步骤一:打开终端 $sudo /etc/init.d/mysql stop $sudo mkdir -p /var/run/mysqld $sudo chown mysql:mysql /var/ru ...
- [CodeForces238E]Meeting Her(图论+记忆化搜索)
Description 题目链接:Codeforces Solution 因为路线随机,所以找出各路线最短路必须经过的点,在这个点必定能上车 直接floyd暴力找割点 然后不断用k条公交车路线来更新D ...
- Black Box POJ1442
Description Our Black Box represents a primitive database. It can save an integer array and has a sp ...
- spark提交运算原理
前面几天元旦过high了,博客也停了一两天,哈哈,今天我们重新开始,今天我们介绍的是spark的原理 首先先说一个小贴士: spark中,对于var count = 0,如果想使count自增,我们不 ...
- 关于原生JS获取class,ID等属性的一些封装
一.传统上获取是通过document.getElementById获取元素的ID属性,通过总结与学习总结一下获取元素class以及id属性的一些封装; 1.创建构造函数,这里面不需要多解释什么:(主要 ...
- STM32无法使用IAR下载程序问题
一开始建立了工程,然后程序下载都很正常.不知道什么情况自己下载代码之后,再重新下载代码无法成功. 我按照提示找了一下FlashStm32f30x8.flash这个文件,却发现IAR的目录下没并没有.又 ...
- [Python3.x]python3.5实现socket通讯(TCP)
TCP连接: tcp是面向连接的一个协议,意味着,客户端和服务器开发发送数据之前,需要先握手创建一个TCP连接.TCP连接的一端与客户端套接字相互联系,另一端与服务器套接字相联系.当创建该TCP连接的 ...