题目传送门

盒子和小球之二:N个有差别的盒子(1<=N<=20)。你有A个红球和B个蓝球。0 <= A <= 15, 0 <= B <= 15。球除了颜色没有任何区别。你可以将球放进盒子。一个盒子可以同时放进两种球,也可以只放一种,也可以空着。球不必全部放入盒子中。编程计算有多少种放置球的方法。

考虑动态规划。一个盒子可以同时放进两种球,但是每个盒子我们可以对他进行很多操作,所以也就可以近似看成每个盒子可以放无数球,但是这并不重要。设f[i][j][k]表示我们当前放到第i个盒子,已经放了j个红球,k个篮球的状态方案数。(因为我们要求在状态设计的时候要求顾及到题目中的重要量,而这个状态恰好达到了这点)另外,由于本题数据范围较小,所以我们思考的不用太复杂。

则我们可以理所当然地想到转移:f[i][j][k]=sigmaf[i-1][j-x][k-x],其中x是我们枚举的在当前盒子中放几个。

时间复杂度为O(n*A^2*B^2),可以轻松通过。

目标答案显然我们可以累加f[n][i][j],枚举ij。

 #include<cstdio>
#include<algorithm> using namespace std;
typedef long long ll;
//complexity n*A^2*B^2
int n,A,B;
ll ans,f[][][]; int main()
{
scanf("%d%d%d",&n,&A,&B);
f[][][]=;//初值,很重要
for(int i=;i<=n;i++)
for(int j=;j<=A;j++)//注意放几个从0开始枚举
for(int k=;k<=B;k++)
for(int a=;a<=j;a++)
for(int b=;b<=k;b++)
f[i][j][k]+=f[i-][j-a][k-b];
for(int i=;i<=A;i++)
for(int j=;j<=B;j++)
ans+=f[n][i][j];//球不必全部放入盒子中
printf("%lld",ans);
return ;
}

盒子与小球之三:有N个相同的球,M个不同的盒子,每个盒子最多放K个球 ,请计算将这N个球全部放入盒子中的方案数模1000007后的结果 ,N<=5000,M<=5000。

我们可以继续考虑动态规划,相似的状态与转移。设f[i][j]为当前放到第i个盒子,已经放了j个球的方案数。显然有转移:

f[i][j]=sigmaf[i-1][j-k],其中k枚举在当前盒子里放了几个。但由于本题数据比上一题大很多,这样的n^3转移会超时。状态设计的没有什么可以优化的了,考虑在转移优化。我们仔细观察转移方程,发现我们要加的其实是连续的一段,这就启示我们可以用前缀和优化,在转移前提前算出在i-1状态下的j前缀和。

 #include<cstdio>
#include<algorithm>
#define maxn 5090 using namespace std;
typedef long long ll; int n,m,k;
ll moder=,f[maxn][maxn],sum[maxn]; int main()
{
scanf("%d%d%d",&n,&m,&k);
for(int i=;i<=m;i++) f[i][]=;
for(int i=;i<=m;i++)
{
for(int j=;j<=n;j++)
(sum[j]=sum[j-]+f[i-][j])%=moder;
for(int j=;j<=n;j++)
{
//if(i==1&&j==1) printf("~~~~%d %d %d\n",sum[j],sum[max(j-k-1,0)],max(j-k-1,0));
if(j-k-<) (f[i][j]=sum[j]+moder)%=moder;
else (f[i][j]=sum[j]-sum[j-k-]+moder)%=moder;
//printf("%d %d:=%d\n",i,j,f[i][j]);
}
}
printf("%lld",f[m][n]);
return ;
}

盒子与小球之四:给定N个各不相同的小球,和M个不同的BOX,有多少种不同的放球方法,使得每个BOX里的小球个数不小于K。N,M,K均小于15。

我们还可以继续考虑动态规划。设f[i][j]表示当前放到第i个盒子,已经放了j个球的方案数。小球个数不小于k,只需要在转移时从k开始枚举。由于本题小球各不相同,所以我们需要组合数。本题数据在15,非常小可以递推预处理出组合数。于是有转移如下:

f[i][j]=sigmaf[i-1][j-k]*C(n-(j-k),k).

 #include<cstdio>
#include<algorithm>
#include<cstring> using namespace std;
typedef long long ll; int n,m,jue;
ll f[][],C[][]; ll Combines()
{
for(int i=;i<=;i++) C[i][]=,C[i][i]=;
for(int i=;i<=;i++)
for(int j=;j<=i;j++)
C[i][j]=C[i-][j]+C[i-][j-];
} int main()
{
Combines();
while(scanf("%d%d%d",&n,&m,&jue)!=EOF&&n!=)
{
memset(f,,sizeof f);
for(int i=jue;i<=n;i++) f[][i]=C[n][i];
for(int i=;i<=m;i++)
for(int j=jue;j<=n;j++)
for(int k=jue;k<=j;k++)
f[i][j]+=C[n-(j-k)][k]*f[i-][j-k];
printf("%lld\n",f[m][n]);
}
return ;
}

NOI题库--盒子和小球系列 By cellur925的更多相关文章

  1. NOI题库刷题日志 (贪心篇题解)

    这段时间在NOI题库上刷了刷题,来写点心得和题解 一.寻找平面上的极大点 2704:寻找平面上的极大点 总时间限制:  1000ms  内存限制:  65536kB 描述 在一个平面上,如果有两个点( ...

  2. NOI题库 1768最大子矩阵 题解

    NOI题库 1768最大子矩阵  题解     总时间限制: 1000ms 内存限制: 65536kB   描述   已知矩阵的大小定义为矩阵中所有元素的和.给定一个矩阵,你的任务是找到最大的非空(大 ...

  3. NOI题库 09:图像旋转翻转变换

    NOI题库开始的题,也是略水,当然也是大水,所以彼此彼此 09:图像旋转翻转变换 总时间限制: 1000ms 内存限制: 65536kB 描述 给定m行n列的图像各像素点灰度值,对其依次进行一系列操作 ...

  4. NOI题库-小学奥赛QwQ

    今天Loli教育我们让我们来看看NOI题库的奥赛部分,不过,为何是小学的( ⊙ o ⊙ )啊!感觉智商被各种侮辱. 余数相同问题: 描述 已知三个正整数 a,b,c. 现有一个大于1的整数x,将其作为 ...

  5. noi题库(noi.openjudge.cn) 1.7编程基础之字符串T31——T35

    T31 字符串P型编码 描述 给定一个完全由数字字符('0','1','2',-,'9')构成的字符串str,请写出str的p型编码串.例如:字符串122344111可被描述为"1个1.2个 ...

  6. NOI题库192 生日蛋糕

    192:生日蛋糕 总时间限制: 5000ms 内存限制: 65536kB 描述 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体. 设从下往上数第i ...

  7. NOI 题库 9272 题解

    9272   偶数个数字3 描述 在所有的N位数中,有多少个数中有偶数个数字3? 输入 一行给出数字N,N<=1000 输出 如题 样例输入 2 样例输出 73 Solution : 令f ( ...

  8. noi题库(noi.openjudge.cn) 1.5编程基础之循环控制T36——T45

    T36 计算多项式的值 描述 假定多项式的形式为xn+xn-1+-+x2+x+1,请计算给定单精度浮点数x和正整数n值的情况下这个多项式的值. 输入 输入仅一行,包括x和n,用单个空格隔开.x在flo ...

  9. noi题库(noi.openjudge.cn) 1.7编程基础之字符串T21——T30

    T21:单词替换 描述 输入一个字符串,以回车结束(字符串长度<=100).该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写.现需要将其中的某个单词替换成另一个单词,并输出替 ...

随机推荐

  1. send-mail: fatal: parameter inet_interfaces: no local interface found for ::1

    转载:http://blog.csdn.net/csdnones/article/details/50717934 发送邮件: [root@iZ23whn33jnZ log]# echo '这是邮件标 ...

  2. Meteor集合

    在本教程中,我们将学习如何使用 MongoDB集合. 创建集合 我们可以使用以下代码来创建一个新的集合- meteorApp/client/main.js MyCollection = new Mon ...

  3. curl 中文乱码

    curl 中文乱码 学习了:https://blog.csdn.net/thc1987/article/details/52583789 学习了: http://blog.itpub.net/2903 ...

  4. LightRoom操作快捷键

    1.隐藏与释放上下左右面板:F5.F6.F7.F8.分别对应上下左右面板.tab键可以隐藏与释放左右面板,shift+table可以同时隐藏与释放所有面板,T键隐藏与显示工具栏 2.图库与修改照片模块 ...

  5. CentOS 6.x Inotify+Rsync

    CentOS 6.x Inotify+Rsync yum -y install lrzsz [root@rsync ~]# mount -t nfs 10.6.100.75:/volume1/pace ...

  6. iOS开发-UITableView单选多选/复选实现1

    TableView怎样实现单选或者多选呢? 我们的直接思路是改动某一个Cell的样式就可以, 那么改动样式须要通过改动相应的数据, 从这里能够判断我们须要给Cell相应的数据设置一个标志位, 当选中的 ...

  7. 在linux命令行中编译和运行java文件

    同时加载编译多个jar包和java文件 在个人平常使用或者当我们把代码部署到linux服务器上的时候,我们经常需要通过命令行编译和运行java文件,网上关于这个的方法大多是通过 javac -cp f ...

  8. SLF4J: Failed to load class的问题及解决

    今天在做接口测试,一运行测试程序,就跳出这样一个大大的错误: SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder”. SLF4 ...

  9. 如何使用jQuery向asp.net Mvc传递复杂json数据

    jQuery提供的ajax方法能很方便的实现客户端与服务器的异步交互,在asp.net mvc 框架使用jQuery能很方便地异步获取提交数据,给用户提供更好的体验! 调用jQuery的ajax方法时 ...

  10. Django框架之ORM

    1,字段和字段的参数 1.1>ORM的概念:对象映射模型(Objects Relational Model)是一种为了解决面向对象和关系型数据库存在的互不匹配的现象和技术,简单的说,ORM是通过 ...