连续N次十连抽卡中,存在连续至少M(M≤N)次十连都不出最高稀有度卡的概率
问题描述
考虑这一种抽卡系统:每进行一次叫做“十连抽卡”(也可能是十一连,不过后面统称为“十连”)的操作,就有的概率抽出“最高稀有度的卡”(具体到某种抽卡系统中,它可能被叫做“UR卡”“SSR式神”“四星卡”“五星从者”“六星干员”等等),当然,也就有
的概率抽不出“最高稀有度的卡”。
现在在这个系统中抽卡(
是正整数)次,考虑这样的一个事件:在这连续的
次抽卡中,存在连续的至少
(
,并且
也是正整数)次“十连抽卡”(比如说,这
次抽卡中的第4,5,6,7,…,M+3次抽卡),使得这
次抽卡都没有抽出“最高稀有度的卡”,或者在下文中简称,没有“出货”。
本文给出了该问题以矩阵形式表示的解,并给出了部分具体问题中,该问题的数值解。

求解过程
1.“没出十连次数计数器”
在进行这次“十连抽卡”的过程中,假想我们在同时操作一个“没出十连次数计数器”(后简称“计数器”)。计数器在这
次“十连抽卡”开始前的初始值为
,随后每抽一次十连,如果没出最高稀有度的卡,就把计数器的值
;如果出了最高稀有度的卡,就把计数器的值重置为
。以一次
的抽卡为例:

这个计数器将帮助我们统计“最多有连续几次十连没出货”,在这个问题中,我们只关心计数器曾到达过的最大值是多少。原题所要求的是“存在连续至少次十连不出货的概率”,其实也就等价于,“计数器曾到达过的某个值≥M的概率”。

2.定义关于计数器的数列{Mn},考察Mn随n的变化规律
接下来我们定义数列为抽卡次数为
时,计数器所显示的数字;由递推关系再定义一关于
的数列:
原题要求“计数器曾到达过的某个值≥M的概率”,也就等价于“的概率”。因为当
时,就意味着
,于是
。反过来,如果已知
,则必然
,于是
。两个条件可以相互推出,因此相互等价。
现来考虑的值,即在已知
的情况下,式
成立的概率。我们将分
与
两种情况来讨论。
当时,显然有:
当时,由
容易推出
,因此
。又因为
(否则
,由
知
,故
不能为
只能为
,又与
矛盾),所以:

3.状态,概率分布与转移矩阵
我们知道只能在
共
个正整数中取值。我们把这些值叫做
所处的状态。
对于值,我们定义一个
维的向量
,称作
的概率分布,其中
是
的值取
的概率大小。自然,
(有
个
)。
再定义行
列的,
的转移矩阵如下:
位于这个矩阵的第行第
列的元素的值,就是
的值。
因此我们有递推关系:。该问题的答案即
的最后一个元素的值,或者说,位于矩阵最右上角的值。问题到此解决。很遗憾,这个问题的答案并不能用简单的公式表示,大多数时候也不能手算。

实际情景
1.公式验证
我们首先用一个简单的情形验证答案的正确性。连抛5次正面朝上概率为二分之一的硬币,则结果中存在连续至少两次正面朝上的概率是多少?
这个问题可以手算。连抛5次硬币,共有种可能的结果。反面朝上次数为0或1时,结果一定符合题意(证略)。反面朝上次数为2时,有且仅有“正反正反正”
种结果不合题意。反面朝上次数为3时,有“正反正反反”“正反反正反”“正反反反正”“反正反正反”“反正反反正”“反反正反正”共
种结果不合题意。反面朝上次数为4或5时,结果一定不合题意,其中,反面朝上次数为4的结果有
种,朝上次数为5的结果有
种。因此,问题的答案是:
再用本文提到的方法计算。把“硬币正面朝上”看作是“没出货”,取:
则,由此可得:
该矩阵最右上角的值正是,与我们手算得到的答案一致,因此这个计算方法是正确无误的。

2.程序编写
由于计算过于复杂,我们首先编写一段Python程序替代人工进行计算并输出结果。程序中N、M、p的含义都与上文相同。
通过以下代码,再次计算前文提到的抛硬币问题:
得到输出:
0.59375就是的小数形式,可见该程序工作正常。

3.投入实战
对于“连续不出货问题”,现在不但有了经验证的理论,还根据理论编写好了程序。万事俱备,现在我们可以尝试解决一些真实的抽卡问题了。当然,这里假设所有游戏的抽卡系统都乖乖采用了宇宙无敌真随机算法来决定抽卡结果,至少,也得看起来像是独立事件。
3.1 在《阴阳师》中,从零开始用10000张蓝票达成大阴阳师成就的概率
《阴阳师》中最高的稀有度为SSR。根据已知信息:大阴阳师成就需要连续500次蓝票抽卡不出SSR,而《阴阳师》每次蓝票抽卡抽出SSR的概率是1%,即不出货的几率为0.99。
根据题目条件,编写并运行如下代码:
输出结果为:
即,能用10000张蓝票从零开始达成大阴阳师成就的概率,大概是47.9%。另外,如果蓝票数量缩减到5000,2000,1000张,则达成概率会分别缩减到约26.8%,10.3%,3.9%。约35K张蓝票可以保证90%以上的达成率。
尽管问题的答案是一个定值(甚至可以确定是一个有理数),但依靠程序求出其准确值实在是很困难,只好求其近似值。好在近似值也大概够用。
3.2 在《BanG Dream!》《世界计划》等游戏中,如果连续抽十连20次,那么出现连续几次以内的“不出彩”是正常的?
《BanG Dream!》和《世界计划》本来是两款完全不同的游戏,但正好两款游戏的最高稀有度都是4星(彩色),且单抽出彩色的概率都恰好是3%(Fes活动期间可以是6%),所以放在一起讨论。
首先考虑任意一次十连不出彩的可能性。一次十连抽出的每一张卡是不是彩色,都是独立事件,因此十连不出彩的可能性是,或者在Fes活动期间为
。
我们运行如下代码进行计算:
输出结果:
不知道这和邦邦人与豆腐人们的体感是否符合呢。顺便对于Fes活动期间的抽卡,运行如下代码:
输出结果为:
那在几次以内的“十连不出彩”是正常的呢?这取决于确定“正常”与“不正常”的界线位于何处。比如说,假定发生了概率在5%及以上的事件算是“正常”的话,那么,非Fes期间连续13次十连无彩,Fes期间连续7次十连无彩,都是“正常”的。
为了方便大家比对自身情况,这里给出两份更具体的表格。



结语
本篇专栏实际上通过随机过程中与马尔科夫链有关的理论,解决了“连续抽卡无彩”问题,欢迎同好们批评指正,也希望能够帮助到大家。■