公式: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]排队 组合数的更多相关文章

  1. 【BZOJ2729】[HNOI2012]排队 组合数

    [BZOJ2729][HNOI2012]排队 Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那 ...

  2. bzoj 2729: [HNOI2012]排队

    2729: [HNOI2012]排队 Time Limit: 10 Sec Memory Limit: 128 MB Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体 ...

  3. 2729: [HNOI2012]排队

    2729: [HNOI2012]排队 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 957  Solved: 449[Submit][Status] ...

  4. 2729:[HNOI2012]排队 - BZOJ

    题目描述 Description某中学有n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人 ...

  5. [HNOI2012]排队

    题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...

  6. BZOJ2729:[HNOI2012]排队(组合数学)

    Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不 ...

  7. P3223 [HNOI2012]排队

    题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...

  8. 洛谷 P3223 [HNOI2012]排队

    题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...

  9. Luogu P3223 [HNOI2012]排队 组合

    本来做了一道  P4901 排队 后来发现自己做错题了...到也都是数学qwq 这题最恶心的就是两只(雾)老师. 那我们分类讨论: 1.两个老师之间是男生: $ A(n,n)*A(n+1,2)*A(n ...

随机推荐

  1. Python之数据处理

    一.CSV数据处理 CSV文件格式:逗号分隔值(Comma-Separated Value,CSV,有时也称为字符分隔值,因为分隔符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本).纯文 ...

  2. PHP用url传递数组

    数组传递这么写:   echo "<a href=2.php?info=".base64_encode(serialize($information))." > ...

  3. MySQL高级-索引优化

    索引失效 1. 2.最佳左前缀法则 4. 8. 使用覆盖索引解决这个问题. 二.索引优化 1.ORDER BY 子句,尽量使用Index方式排序,避免使用FileSort方式排序 MySQL支持两种方 ...

  4. JQuery.extend扩展实现同步post请求

    有时需要在jQuery中实现同步post请求,而jquery自带的是异步,需要通过JQuery.extend扩展. 支持ie和firefox,方法转载而来.需要在submit前将form.append ...

  5. 「日常训练」 Counting Cliques(HDU-5952)

    题意与分析 题源:2016ACM/ICPC沈阳现场赛. 这题让我知道了什么是团,不过最恶心的还是这题的数据了,卡了无数次- - 解决方法是维护一个G数组,不能去遍历邻接矩阵.至少我改了这么一个地方就过 ...

  6. Qt-QML-自定义个自己的文本Text

    好久都没有正经的更新自己的文章了,这段时间也辞职了,听了小爱的,准备买个碗,自己当老板,下面请欣赏效果图 这个界面布局就是自己是在想不到啥了,按照常规汽车导航的布局布局了一下,主要看内容哈,看看这个文 ...

  7. 初学DirectX(1)

    初学Direct X (1) Direct3D设备用于访问视频卡的帧缓冲区,以及后台缓冲区.由于IDE是vs2013,默认安装了direct 9,只需要在使用头文件(1)并像使用库文件(2)即可 #i ...

  8. Linux搭建mysql、apache、php服务总结

    本随笔文章,由个人博客(鸟不拉屎)转移至博客园 写于:2018 年 04 月 22 日 原地址:https://niaobulashi.com/archives/linux-mysql-apache- ...

  9. Linux 文件的常识

    文件 文件的分类 文件 目录 链接 区分办法,ls -la 查看 十个标志符中的第一个 如:drwxrwxr-x. 2 normal normal 4096 8月 31 23:43 dir 目录是d ...

  10. JAVA 面试须知

    本篇文章会对面试中常遇到的Java技术点进行全面深入的总结,帮助我们在面试中更加得心应手,不参加面试的同学也能够借此机会梳理一下自己的知识体系,进行查漏补缺. 1. Java中的原始数据类型都有哪些, ...