题目传送门


题目描述

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


输入格式

只有一行且为用空格隔开的两个非负整数n和m,其含义如上所述。


输出格式

输出文件output.txt仅包含一个非负整数,表示不同的排法个数。注意答案可能很大。


数据范围与提示

对于30%的数据:n≤100,m≤100
对于100%的数据:n≤2000,m≤2000


题解

一道组合数学的入门题,还不会组合数学的可以跳转这篇博客:组合数学入门

ppt上的例题,附带讲解:

将男生和女生混在一起,将女生往里插

如果两个老师在一起,方案数为$A_{n+1}^{n+1}$×$A_{2}^{2}$

两个老师之间必须插进一个女生

将两个老师和一个女生打包成一坨当成一个男生

方案数为m×$A_{n+1}^{n+1}$×$A_{2}^{2}$

剩余m-1个女生,插进n+2个空位中

总方案数为m×$A_{n+1}^{n+1}$×$A_{2}^{2}$×$A_{m-1}^{m-1}$×$C_{n+2}^{m-1}$

如果两个老师不在一起,方案数为$A_{n+2}^{n+2}$-$A_{n+1}^{n+1}$×$A_{2}^{2}$

此时女生随便插,方案数为($A_{n+2}^{n+2}$-$A_{n+1}^{n+1}$×$A_{2}^{2}$)×$A_{m}^{m}$×$C_{n+3}^{m}$

最终答案为:m×$A_{n+1}^{n+1}$×$A_{2}^{2}$×$A_{m-1}^{m-1}$×$C_{n+2}^{m-1}$+($A_{n+2}^{n+2}$-$A_{n+1}^{n+1}$×$A_{2}^{2}$)×$A_{m}^{m}$×$C_{n+3}^{m}$

但是呢?我懒。

这也太麻烦了吧?!

于是,自己推式子:

依然分类讨论:

先讨论两个老师中间只站一个女生,将老师和那个女生看为一个整体:

$A_{m}^{1}$×$A_{n}^{n}$×$A_{n+1}^{1}$×$A_{2}^{2}$×$A_{n+2}^{m-1}$。

接着讨论两个男生中间站一个老师的情况:

$A_{n}^{n}$×$A_{n+1}^{2}$×$A_{n+3}^{m}$。

然后整理化简得:(n2+3×n+2×m)×(n+1)!×(n-m+4)×(n-m+5)×…×(n+2)。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int n,m;
int l=1;
long long ans[100001],flag1,flag2;
void wzc(int x)//高精乘低精
{
flag2=0;
for(int i=1;i<=l;i++)
{
flag1=ans[i]*x;
ans[i]=flag1%1000000000000000+flag2;
flag2=flag1/1000000000000000;
}
if(flag2)ans[++l]=flag2;
}
int main()
{
ans[1]=1;
scanf("%d%d",&n,&m);
wzc(n*n+n*3+2*m);
for(int i=1;i<=n+1;i++)
wzc(i);
for(int i=n-m+4;i<=n+2;i++)
wzc(i);
cout<<ans[l];
while(--l)
{
cout.fill('0');//不足补0
cout<<setw(15)<<ans[l];
}
return 0;
}

rp++

[BZOJ2729]:[HNOI2012]排队(组合数学)的更多相关文章

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

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

  2. 【bzoj2729】[HNOI2012]排队 组合数学+高精度

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

  3. BZOJ2729 [HNOI2012]排队 【高精 + 组合数学】

    题目链接 BZOJ2729 题解 高考数学题... 我们先把老师看做男生,女生插空站 如果两个老师相邻,我们把他们看做一个男生,女生插空站 对于\(n\)个男生\(m\)个女生的方案数: \[n!m! ...

  4. BZOJ2729 HNOI2012排队(组合数学+高精度)

    组合入门题.高精度入门题. #include<iostream> #include<cstdio> #include<cstdlib> #include<cs ...

  5. bzoj2729 [HNOI2012]排队

    组合数学,推一下式子,并不难推. java代码 import java.io.*; import java.math.BigInteger; import java.util.*; public cl ...

  6. [bzoj2729][HNOI2012]排队 题解 (排列组合 高精)

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

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

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

  8. bzoj 2729: [HNOI2012]排队

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

  9. 2729: [HNOI2012]排队

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

随机推荐

  1. [洛谷P4183][USACO18JAN]Cow at Large P

    题目链接 Bzoj崩了之后在洛谷偶然找到的点分好题! 在暴力的角度来说,如果我们$O(n)$枚举根节点,有没有办法在$O(n)$的时间内找到答案呢? 此时如果用树形$dp$的想法,发现是可做的,因为可 ...

  2. 洛谷 P1134 阶乘问题 题解

    题面 很裸的边取模边乘.注意因为进位的原因模数应该比较大: 另外,这道题是一道标准的分块打表例题(那样的话数据就可以更大了),可以用来练习分块打表: #include<bits/stdc++.h ...

  3. c++ Convert struct to bytes

    D:\stock\Tskingfromgoogle\src\NetTS\TW.cpp Convert struct  to bytes //Convert struct to bytes 2019/0 ...

  4. Comet OJ - Contest #13

    Rank53. 第一次打这种比赛.还是有不少问题的,以后改吧. A题WA了两次罚了不少时. C写到一半发现只能过1,就先弃了. D一眼没看出来.第二眼看出来就是一个类似于复数的快速幂. 然后B切了. ...

  5. P1106 删数问题

    展开 题目描述 键盘输入一个高精度的正整数NN(不超过250250位) ,去掉其中任意kk个数字后剩下的数字按原左右次序将组成一个新的正整数.编程对给定的NN和kk,寻找一种方案使得剩下的数字组成的新 ...

  6. homestead安装swoole扩展

    配置好ubuntu的国内镜像源并更新 查看php版本,并安装对应php版本的dev sudo apt install php7.2-dev 配置pecl sudo pecl channel-updat ...

  7. tf-图像预处理

    tensorflow 中自带了很多图像处理的方法,基本都在 tf.image 模块中,虽然不如 opencv 强大,但也比较常用,这里做个记录. 图像编解码 1. 用 tf 的方法读取图片后,都需要进 ...

  8. 26. Remove Duplicates from Sorted Array(代码思路新奇)

    Given a sorted array, remove the duplicates in-place such that each element appear only once and ret ...

  9. Android 调用摄像头功能【拍照与视频】

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/ma_hoking/article/details/28292973 应用场景: 在Android开发 ...

  10. jstl用法 简介

    <c:choose> <c:when test="${salary <= 0}"> 太惨了. </c:when> <c:when t ...