标签:Blue 方案 Balls 红球 int 132 le 蓝球 include
题目描述
给定\(K\)个蓝球和\(N - K\)个红球,这\(N\)个球从左到右排成一列,\(Takahashi\)可以每次选连续的若干个蓝球直至蓝球被选完,他会在尽可能少的步数内完成。
问有多少种球的摆放方式使得\(Takahashi\)可以在恰好\(i(1 \le i \le K)\)步内取完所有蓝球?由于方案数很多,输出\(\mod 1e9 + 7\)后的结果。
数据范围
\(1 \le K \le N \le 2000\)
题解
本题是一个计数题,可以通过排列组合直接进行计算。
- 首先将\(K\)个蓝球分为\(i\)组,有\(C_{k - 1}^{i - 1}\)种方案数
- 然后考虑用红球将蓝球间隔开,有以下三种方案。
- 将\(N - K\)个红球分为\(i\)组,有\(C_{N - K - 1}^{i - 1}\)种方案,考虑到\(i\)组红球与\(i\)组蓝球交替排放有两种方案,故总方案数为\(2 * C_{N - K - 1}^{i - 1}\)
- 将\(N - K\)个红球分为\(i - 1\)组,有\(C_{N - K - 1}^{i - 2}\)种方案
- 将\(N - K\)个红球分为\(i + 1\)组,有\(C_{N - K - 1}^{i}\)种方案
- 综上,最后的方案数有\(C_{k - 1}^{i - 1} * (2 * C_{N - K - 1}^{i - 1} + C_{N - K - 1}^{i - 2} + C_{N - K - 1}^{i})\)种。
但若直接按照上述公式写成代码,在避免RE
错误加特判的过程中会导致答案错误,当然这是由于对计算过程理解不够导致的,这种情况可以先化简公式,也可以构造特殊样例发现错误
使用的化简公式是\(C_{n}^{m} = C_{n - 1}^{m - 1} + C_{n - 1}^{m}\)
代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
const int N = 2010, mod = 1e9 + 7;
int n, k;
ll c[N][N];
void init(){
for(int i = 0; i < N; i ++)
for(int j = 0; j <= i; j ++)
if(!j) c[i][j] = 1;
else c[i][j] = (c[i - 1][j] + c[i - 1][j - 1]) % mod;
}
int main()
{
init();
scanf("%d%d", &n, &k);
for(int i = 1; i <= k; i ++){
ll ans = c[k - 1][i - 1] * c[n - k + 1][i] % mod;
printf("%lld\n", ans);
}
return 0;
}
标签:Blue,方案,Balls,红球,int,132,le,蓝球,include
来源: https://www.cnblogs.com/bxhbxh/p/16368136.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。