[HNOI2012]排队 组合数
公式:A(n,n)*A(n+1,2)*A(n+3,m) + A(n,n)*C(m,1)*A(2,2)*C(n+1,1)*A(n+2,m-1)
分情况讨论推出公式
前者为无论何时都合法的,后者为先不合法,然后再合法的(两个老师先站在一 起,然后一个女生
插进来,所以要把这3个人看成一个整体,然后老师可以左右换,所以乘2,女生 就是m选1,然后整体再插入队伍
最后得到上面的式子
由于答案较大,所以要写高精
#include<bits/stdc++.h>
using namespace std;
#define AC 10000
#define R register int
#define D printf("the k is %d\n",k);
/*A(n,n)*A(n+1,2)*A(n+3,m) + A(n,n)*C(m,1)*A(2,2)*C(n+1,1)*A(n+2,m-1)
分情况讨论推出公式
前者为无论何时都合法的,后者为先不合法,然后再合法的(两个老师先站在一 起,然后一个女生
插进来,所以要把这3个人看成一个整体,然后老师可以左右换,所以乘2,女生 就是m选1,然后整体再插入队伍
最后得到上面的式子
*/
int sum2[AC],a[AC],sum1[AC],k,n,m,tot,tot1,tot2,ans[AC];//每次计 算前将memset a,将高精sum*低精k存入a,然后计算完毕后将a导入sum void ADD()//加法
{
for(R i=;i<=max(tot1,tot2);i++)//error!!!注意这里要加到max(tot1,tot2)!!!
{
ans[i+]=ans[i+]+(sum1[i]+sum2[i]+ans[i])/;
ans[i]=(ans[i]+sum1[i]+sum2[i])%;
}
tot=(tot1+tot2)%;
while(!ans[tot] && tot>)--tot;//注意边界!!!
} void add1()//乘法1,计算前一部分
{
memset(a,,sizeof(a));
for(R i=;i<=tot1;i++)
{
a[i+]=a[i+]+(a[i]+sum1[i]*k)/;
a[i]=(a[i]+sum1[i]*k)%;
}
tot1+=;//因为n和m最大就是2000,所以最多也就加这么多位了,又因为压了位,,,所以
while(!a[tot1] && tot1>)--tot1;
if(!a[tot1])memset(sum1,,sizeof(sum1));//如果女生太多了会导致没有合法情况!!
else for(R i=;i<=tot1;i++) sum1[i]=a[i];//导入sum
} void add2()//乘法2,计算后一部分
{
memset(a,,sizeof(a));
for(R i=;i<=tot2;i++)
{
a[i+]=a[i+]+(a[i]+sum2[i]*k)/;
a[i]=(a[i]+sum2[i]*k)%;
}
tot2+=;//因为n和m最大就是2000,所以最多也就加这么多位了,又因为压了位,,,所以
while(!a[tot2] && tot2>)--tot2;
if(!a[tot2])memset(sum2,,sizeof(sum2));
else for(R i=;i<=tot2;i++) sum2[i]=a[i];//导入sum
} void work()
{
sum1[]=;//初始值
tot1=;
for(R i=;i<=n;i++)//计算A(n,n),即n!
{
k=i;
add1();
}
k=n;
add1();
k=n+;//分开乘,不然k太大会爆
add1();
k=n+;
for(R i=;i<=m;i++)//计算A(n+3,m)
{
add1();
--k;
}
//一二部分分割线~~~~~~~~~~~~~~~
sum2[]=*(n+);//不会破万,所以直接放在第一个即可
tot2=;
k=m;
add2();
for(R i=;i<=n;i++)
{
k=i;
add2();
}
k=n+;
for(R i=;i<=m-;i++)
{
add2();
--k;
}
ADD();//最后把sum1和sum2相加得到ans
printf("%d",ans[tot--]);
for(R i=tot;i>=;i--)printf("%04d",ans[i]);
/*printf("\n");
while(!sum1[tot1])tot1--;
printf("%d",sum1[tot1]);
for(R i=tot1-1;i>=1;i--)printf("%04d",sum1[i]);*/
} int main()
{
freopen("in.in","r",stdin);
scanf("%d%d",&n,&m);
work();
fclose(stdin);
return ;
}
[HNOI2012]排队 组合数的更多相关文章
- 【BZOJ2729】[HNOI2012]排队 组合数
[BZOJ2729][HNOI2012]排队 Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那 ...
- bzoj 2729: [HNOI2012]排队
2729: [HNOI2012]排队 Time Limit: 10 Sec Memory Limit: 128 MB Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体 ...
- 2729: [HNOI2012]排队
2729: [HNOI2012]排队 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 957 Solved: 449[Submit][Status] ...
- 2729:[HNOI2012]排队 - BZOJ
题目描述 Description某中学有n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人 ...
- [HNOI2012]排队
题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...
- BZOJ2729:[HNOI2012]排队(组合数学)
Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不 ...
- P3223 [HNOI2012]排队
题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...
- 洛谷 P3223 [HNOI2012]排队
题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...
- Luogu P3223 [HNOI2012]排队 组合
本来做了一道 P4901 排队 后来发现自己做错题了...到也都是数学qwq 这题最恶心的就是两只(雾)老师. 那我们分类讨论: 1.两个老师之间是男生: $ A(n,n)*A(n+1,2)*A(n ...
随机推荐
- 利尔达NB-IOT模组Coap数据AT+NMGS发送时返回-513的原因
1. 利尔达NB-IOT模组使用AT+NMGS发送数据,返回-513的问题,大致有3种可能性,在硬件上,模组的射频电路分为A型和B型模组,所以烧写固件的时候,也要分为A和B型固件,如果烧写反了,那么R ...
- xencenter迁移云主机方法
问题:POOL中计算节点内存不足. 解决方法:1.为计算节点添加内存(费用高)2.将部分资源迁移到其它POOL中. 方法: 1.选择要迁移的虚拟机 2.选择保存路径 这里可以看到可以批量导出: 注意: ...
- Spark性能优化--开发调优与资源调优
参考: https://tech.meituan.com/spark-tuning-basic.html https://zhuanlan.zhihu.com/p/22024169 一.开发调优 1. ...
- CRL2.1更新
增加没有主键ID的抽象类,使能自义主键字段实现MODEL抽象类定义结构为 /// <summary> /// 基类,不包含任何字段 /// 如果有自定义主键名对象,请继承此类型 /// & ...
- OpenSUSE 11 安装Qt5.0,失败,失败,失败,留个坑,以后来填,万一实现了呢
我又来无耻的写问题来了,这次还真的是没有解决,线留坑吧,万一以后实现了. 同样,这次也是以恶搞网友说听说想在open suse 上面安装5.0版本以后的Qt,自己折腾好几没有成功. 我一想,哎,这不是 ...
- 【CentOS】下安装RabbitMQ教程
系统版本: 安装依赖: 由于RabbitMQ依赖Erlang, 所以需要先安装Erlang. Erlang的安装方式大概有两种: (1) Erlang Solution安装(推荐) wget http ...
- python程序设计——函数设计与调用
一.函数定义与调用 def 函数名([参数列表]): '''注释''' 函数体 # 输出小于n的斐波那契数 >>def fib(n): a,b=1,1 while a < n: pr ...
- TensorFlow入门之MNIST最佳实践-深度学习
在上一篇<TensorFlow入门之MNIST样例代码分析>中,我们讲解了如果来用一个三层全连接网络实现手写数字识别.但是在实际运用中我们需要更有效率,更加灵活的代码.在TensorFlo ...
- [leetcode-779-K-th Symbol in Grammar]
On the first row, we write a 0. Now in every subsequent row, we look at the previous row and replace ...
- 算法模板の数学&数论
1.求逆元 int inv(int a) { ) ; return (MOD - MOD / a) * inv(MOD % a); } 2.线性筛法 bool isPrime[MAXN]; int l ...