Atcoder 题面传送门 & 洛谷题面传送门

无穷级数求和的简单题,稍微写写吧,正好也算帮我回忆下组合数这一块的内容。

首先我们不妨假设 A 赢,B 赢的情况就直接镜像一下即可。我们枚举 B 在 A 赢之前赢了多少局,设为 \(j\),由于题目规定只要有人赢的局数到达 \(n\) 就停止,因此最后一场比赛必须是 A 赢,而前面相当于在 \(n-1+j\) 个场次中选择 \(n-1\) 场留给 A 赢,剩余留给 B 赢,方案数 \(\dbinom{n-1+j}{n-1}\),而 A 赢 \(n\) 场的概率为 \(A^n\),B 赢 \(j\) 场的概率为 \(B^j\),因此这部分的概率为 \(\dbinom{n-1+j}{n-1}\times A^n\times B^j\)。

接下来考虑平局的问题,按照套路我们枚举有多少次平局,设为 \(i\),显然 \(i\) 场平局的概率为 \(C^i\),而将 \(i\) 场平局插入原本 \(n-1+j\) 场分出胜负的比赛,根据隔板法可知方案数为 \(\dbinom{n-1+j+i}{i}\),最后乘上个比赛次数 \(i+j+n\) 就是期望,因此我们可以初步得到答案的表达式:

\[ans_A=\sum\limits_{j=0}^{n-1}\dbinom{n-1+j}{n-1}\times A^n\times B^j\sum\limits_{i=0}^{\infty}C^i\dbinom{n-1+j+i}{i}\times(n+j+i)
\]

由于这是个无穷级数,无法直接求和,需将其转化为封闭形式后再计算。注意到后面的 \(\sum\limits_{i=0}^{\infty}C^i\dbinom{n-1+j+i}{i}\times(n+j+i)\),如果不看那个 \(\times(n+j+i)\),是非常容易转化为封闭形式的,根据生成函数的知识它就是 \(\dfrac{1}{(1-C)^{n+j}}\),重点在于后面的 \(\times(n+j+i)\) 怎样处理,一个想法是将 \(n+j+i\) 拆成 \(n+j\) 和 \(i\),前面的 \(\sum\limits_{i=0}^{\infty}C^i\dbinom{n-1+j+i}{i}\times(n+j)\) 相当好处理,直接乘个 \(n+j\) 即可,但是 \(\sum\limits_{i=0}^{\infty}C^i\dbinom{n-1+j+i}{i}\times i\) 比较棘手,我花费了九牛二虎之力找这东西的封闭形式,xtbz,果然 wtcl 了啊(

注意到 \((n+j+i)\) 与前面二项式系数的 \(n-1+j+i\) 只差一个 \(1\),因此很容易联想到吸收恒等式 \(\dbinom{n}{k}\times k=\dbinom{n-1}{k-1}\times n\),但是如果直接化后面还是会多出个 \(i\),等于啥都没干,不过显然 \(\dbinom{n-1+j+i}{i}=\dbinom{n-1+j+i}{n+j-1}\),而 \(\dbinom{n-1+j+i}{n+j-1}\times(n+j+i)=\dbinom{n+j+i}{n+j}\times(n+j)=\dbinom{n+j+i}{i}\times(n+j)\),故 \(\sum\limits_{i=0}^{\infty}C^i\dbinom{n-1+j+i}{i}\times(n+j+i)=\sum\limits_{i=0}^{\infty}C^i\dbinom{n+j+i}{i}\times(n+j)\),噫,好,\(i\) 没了,这下就可以直接套公式求和了,故:

\[ans_A=\sum\limits_{j=0}^{n-1}\dbinom{n-1+j}{n-1}\times A^n\times B^j\times\dfrac{1}{(1-C)^{n+j+1}}\times(n+j)
\]

随便算一下即可,时间复杂度 \(\mathcal O(n)/\mathcal O(n\log n)\),取决于你怎么实现。

最后,无限 orz ycx,他的方法比我不知道简便到哪里去了 !!!11

const int MAXN=2e5;
const int INV100=5.7e8+4;
const int MOD=1e9+7;
int qpow(int x,int e){
int ret=1;
for(;e;e>>=1,x=1ll*x*x%MOD) if(e&1) ret=1ll*ret*x%MOD;
return ret;
}
int n,A,B,C,fac[MAXN*2+5],ifac[MAXN*2+5];
void init_fac(int n){
fac[0]=ifac[0]=ifac[1]=1;
for(int i=2;i<=n;i++) ifac[i]=1ll*ifac[MOD%i]*(MOD-MOD/i)%MOD;
for(int i=1;i<=n;i++) fac[i]=1ll*fac[i-1]*i%MOD,ifac[i]=1ll*ifac[i-1]*ifac[i]%MOD;
}
int binom(int x,int y){return 1ll*fac[x]*ifac[y]%MOD*ifac[x-y]%MOD;}
int main(){
scanf("%d%d%d%d",&n,&A,&B,&C);
A=1ll*A*INV100%MOD;B=1ll*B*INV100%MOD;C=1ll*C*INV100%MOD;
init_fac(n*2);C=qpow(MOD+1-C,MOD-2);int ans=0;
// printf("%d %d %d\n",A,B,C);
for(int i=0;i<n;i++){
ans=(ans+1ll*binom(n-1+i,n-1)*qpow(A,n)%MOD*qpow(B,i)%MOD*qpow(C,n+i+1)%MOD*(n+i))%MOD;
ans=(ans+1ll*binom(n-1+i,n-1)*qpow(B,n)%MOD*qpow(A,i)%MOD*qpow(C,n+i+1)%MOD*(n+i))%MOD;
} printf("%d\n",ans);
return 0;
}

Atcoder M-SOLUTIONS Programming Contest C - Best-of-(2n-1)(无穷级数求和+组合恒等式)的更多相关文章

  1. AtCoder SoundHound Inc. Programming Contest 2018 E + Graph (soundhound2018_summer_qual_e)

    原文链接https://www.cnblogs.com/zhouzhendong/p/AtCoder-SoundHound-Inc-Programming-Contest-2018-E.html 题目 ...

  2. AtCoder diverta 2019 Programming Contest 2

    AtCoder diverta 2019 Programming Contest 2 看起来我也不知道是一个啥比赛. 然后就写写题解QWQ. A - Ball Distribution 有\(n\)个 ...

  3. 【AtCoder】M-SOLUTIONS Programming Contest

    M-SOLUTIONS Programming Contest A - Sum of Interior Angles #include <bits/stdc++.h> #define fi ...

  4. 【AtCoder】AISing Programming Contest 2019

    本来以为是1199rated的..仔细一看发现是1999,所以就做了一下 这场涨分很轻松啊...为啥又没打 等pkuwc考完我一定打一场atcoder(咕咕咕,咕咕咕,咕咕咕咕咕咕咕~) 但是其实我思 ...

  5. Atcoder ZONe Energy Programming Contest C - MAD TEAM(二分)

    文章目录 题面 Sample Input Sample output 题解 CODE 别的做法 暴力 Dynamic Programming 题面 你想从 N N N 个候选人中选 3 个人. 每个人 ...

  6. 【AtCoder】Yahoo Programming Contest 2019

    A - Anti-Adjacency K <= (N + 1) / 2 #include <bits/stdc++.h> #define fi first #define se se ...

  7. 【AtCoder】KEYENCE Programming Contest 2019

    A - Beginning 这个年份恐怕需要+2 #include <bits/stdc++.h> #define fi first #define se second #define p ...

  8. 【AtCoder】Dwango Programming Contest V题解

    A - Thumbnail 题意简述:给出N个数,找出N个数中和这N个数平均值绝对值最小的数 根据题意写代码即可= = #include <bits/stdc++.h> #define f ...

  9. [AtCoder] NIKKEI Programming Contest 2019 (暂缺F)

    [AtCoder] NIKKEI Programming Contest 2019   本来看见这一场的排名的画风比较正常就来补一下题,但是完全没有发现后两题的AC人数远少于我补的上一份AtCoder ...

随机推荐

  1. Vue3学习(七)之 列表界面数据展示

    一.前言 昨晚可能是因为更新完文章后,导致过于兴奋睡不着(写代码确实太容易让人兴奋了),结果两点多才睡着,大东北果然还是太冷了. 不知道是不是因为膝盖和脚都是冰凉的,所以才导致很晚才能入睡? 刚眯了一 ...

  2. 23.合并k个有序链表

    合并 k 个排序链表,返回合并后的排序链表.请分析和描述算法的复杂度. 示例: 输入: [   1->4->5,   1->3->4,   2->6 ] 输出: 1-&g ...

  3. Qt字符编码小知识

    1.VS2010默认编码是GBK,Qt5的内置编码是utf-8,想要在VS2010及其以上版本,优雅的使用utf-8的字符编码需要 // Coding: UTF-8(BOM) #if defined( ...

  4. 线程池系列二:一张动图,彻底懂了execute和submit

    ​ 我们知道线程池通过execute方法执行提交的Runnable任务,但Runnable只是执行任务,没有返回任何信息. [线程池原理:线程池原来是个外包公司,打工人我悟了] 若是我们想在异步执行完 ...

  5. SprinMvc快速入门

    1.spring mvc Spring MVC是Spring Framework的一部分,是基于Java实现MVC的轻量级Web框架. 查看官方文档:https://docs.spring.io/sp ...

  6. 前端面试手写代码——JS数组去重

    目录 1 测试用例 2 JS 数组去重4大类型 2.1 元素比较型 2.1.1 双层 for 循环逐一比较(es5常用) 2.1.2 排序相邻比较 2.2 查找元素位置型 2.2.1 indexOf ...

  7. Java 中 List 分片的 5 种方法!

    前些天在实现 MyBatis 批量插入时遇到了一个问题,当批量插入的数据量比较大时,会导致程序执行报错,如下图所示: 原因是 MySQL 只能执行一定长度的 SQL 语句,但当插入的数据量较多时,会生 ...

  8. 从0到1搭建自己的组件(vue-code-view)库(上)

    0x00 前言 本文将从结构.功能等方面讲解下项目 vue-code-view 的搭建过程,您可以了解以下内容: 使用 vue cli 4从0搭建一个组件库及细致配置信息. 项目的多环境构建配置. 项 ...

  9. 修改openstack镜像--支持root密码登陆

    一.前言 从openstack官方下载的云镜像一般都是普通用户密钥登陆,比如centos镜像的普通用户为centos,ubuntu镜像的普通用户为ubuntu,虽然密钥登陆系统相比密码登陆来说比较方便 ...

  10. js之变量与数据类型

    变量 声明 一个变量被重新复赋值后,它原有的值就会被覆盖,变量值将以最后一次赋的值为准. var age = 18; age = 81; // 最后的结果就是81因为18 被覆盖掉了 同时声明多个变量 ...