[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 ...
随机推荐
- SpringBoot学习:整合MyBatis,使用Druid连接池
项目下载地址:http://download.csdn.NET/detail/aqsunkai/9805821 (一)添加pom依赖: <!-- https://mvnrepository.co ...
- react-native android 初始化问题
最近开始接触rn,官方起手,装了一堆工具,然后启动项目的时候出现了一堆问题,这里针对我遇到的一些问题提供一些解决方案. 本人开发环境mac,在启动ios的时候没啥大问题,可以直接启动,这里提示一点,因 ...
- C 数数位 while循环
#include <stdio.h> int main(int argc, char **argv) { //定义两个变量 x n 把n初始化 int x; int n=0; //输入x ...
- python爬虫基础之一(爬淘宝)
没想到python如此强大, 今天看一会视频学会了一段python爬虫 这就是我今天学到的内容爬去淘宝网关于书包的一些信息,包括价格, #coding=utf-8 import requests#导入 ...
- 227. Mock Hanoi Tower by Stacks【LintCode java】
Description In the classic problem of Towers of Hanoi, you have 3 towers and N disks of different si ...
- post接口_ajax上传
Action() { web_reg_save_param("find_msg", "LB=message\":\"", "RB= ...
- HTML 之 表单
关于HTML的表单 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset=&q ...
- 人脸识别 ArcFace Demo [Windows]
Arcsoft ArcfaceDemo for Windows, VS2013 C++ 使用虹软技术开发完成 使用步骤: 1.下载SDK包,32位Windows平台将五个SDK包里lib中的文件到 ...
- 在本地电脑使用远程服务器的图形界面——包括 MATLAB、PyCharm 等各种软件
在用本地电脑连接远程服务器的时候,大部分时候只能用命令行来操作.虽然可以 在本地电脑用 PyCharm 进行远程调试.在本地电脑远程使用服务器的 Jupyter Notebook.Ubuntu 和 W ...
- Linux系统查看系统版本命令
以下操作在centos系统上实现,有些方式可能只适用centos/redhat版本系统 uname -a |uname -r查看内核版本信息 [root@node1 ~]# uname -a Linu ...