不想弄题面了。。。

题解

做这道题目我真的好蠢。。。

好容易的数学题目

很明显自己写高精度吧。。。(不解释了)

被dalaoD了,底下的题解可能是假的。看代码里的注释把QaQ

/*

剩下的如何计算。

要有两类情况

①老师之间有男生

那么,这种情况下,直接插空就行了

先把M个女生插进去A(m,n+1)

再把2个老师插进去A(2,n+m+1)

②老师之间只有一个女生

先选出一个女生,放在老师之间A(1,m)

再把剩下的女生插进男生中A(m-1,n+1)

最后把老师和女生看成整体放进去A(1,m+n)

因为老师之间位置可以互换,还有乘2

*/

最后两类直接相加即可

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
inline int read()
{
register int x=0,t=1;
register char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-'){t=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
return x*t;
}
struct BigInt
{
int s[1000000];
int ws;
void Prepare()
{
s[1]=1;
ws=1;
}
void Multi(int x)
{
for(int i=1;i<=ws;++i)s[i]*=x;
for(int i=1;i<=ws;++i)s[i+1]+=s[i]/10,s[i]%=10;
while(s[ws+1])ws+=1,s[ws+1]+=s[ws]/10,s[ws]%=10;
}
void write()
{
for(int i=ws;i;--i)printf("%d",s[i]);
printf("\n");
}
}Ans1,Ans2;
int main()
{
int N=read(),M=read();
//第一种情况,老师之间插男生
Ans1.Prepare();
for(int i=2;i<=N;++i)Ans1.Multi(i);
Ans1.Multi(N+1);Ans1.Multi(N);
for(int i=1;i<=M;++i)Ans1.Multi(N+4-i);
//第二种情况,老师之间插女生
//首先选出一个女生放在老师之间
Ans2.Prepare();
Ans2.Multi(M);
Ans2.Multi(2);
//作为一个整体丢在男生之间
for(int i=1;i<=N;++i)Ans2.Multi(i+1);
//再把女生放进来
for(int i=1;i<M;++i)Ans2.Multi(N+3-i);
if(Ans1.ws<Ans2.ws)swap(Ans1,Ans2);
for(int i=1;i<=Ans2.ws;++i)Ans1.s[i]+=Ans2.s[i];
for(int i=1;i<=Ans1.ws;++i)Ans1.s[i+1]+=Ans1.s[i]/10,Ans1.s[i]%=10;
while(Ans1.s[Ans1.ws+1])Ans1.ws++,Ans1.s[Ans1.ws+1]+=Ans1.s[Ans1.ws]/10,Ans1.s[Ans1.ws]%=10;
Ans1.write();
return 0;
}

【BZOJ2729】【HNOI2012】排队(组合数学)的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. bzoj2729 [HNOI2012]排队

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

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

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

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

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

  9. bzoj 2729: [HNOI2012]排队

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

  10. 2729: [HNOI2012]排队

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

随机推荐

  1. caffe中Makefile.config详解

    ## Refer to http://caffe.berkeleyvision.org/installation.html # Contributions simplifying and improv ...

  2. block,inline,inline-block的区别

    最近正在复习,紧张地准备几天后的笔试,然后刚好看到这个地方. block:块级元素,会换行,如div,p,h1~h6,table这些,可以设置宽高:    inline:行内元素,不换行,挤在一行显示 ...

  3. spring boot学习资源

    http://blog.csdn.net/u014695188/article/details/52226134 http://www.jianshu.com/p/887c22723e43 Sprin ...

  4. iOS 使用NTP时间同步服务

    githup上有相关开源库, ios-ntp 导入即可使用 NetworkClock *netClock = [NetworkClock sharedNetworkClock]; netClock.n ...

  5. 从此不再担心键盘遮住输入框OC(一)

    文/Jiar_(简书作者)原文链接:http://www.jianshu.com/p/48993ff982c1著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 新版本在这里:从此不再担心 ...

  6. 手把手教你树莓派实现简易室内监控系统(C)之BOA服务器的搭建

    本篇主要讲利用BOA服务器做室内监控系统的服务器端. 古人云:万事开头靠百度,实在不行就Google.小编也是一步一步的,亲自搭建成功,不能说是万全之策,仅仅是给大家一个参考就满足了. 第一步: 1. ...

  7. iOS程序闪退的原因以及处理办法

    iOS程序闪退是一种比较常见的现象.闪退的情况很多,造成程序闪退的原因也很多. ================================启动时闪退======================= ...

  8. hdu 2018递推

    第n月的牛的数量由第n-1个月的老牛加上n-1个月新生的小牛,得到公式F(n)=F(n-1)+F(n-3) AC代码: #include<cstdio> const int maxn=55 ...

  9. JavaScript将小写金额转换成大写

    //num为小写金额,单位元 changeMoney(num) { if(isNaN(num))return ""; var strPrefix=""; if( ...

  10. HttpClient调用RestFul接口(post和get方式)

    /** * @version V1.0 * @Description 调用http接口工具类 * @Author pc * @Date 2018/3/2 11:03 */public class Ht ...