优客文库提供全面的范文格式和文档模板,包括申请书、合同、借据、证明、求职信等,助力您快速撰写专业文档。

请用java代码实现以下算法:在抽奖未触发大保底机制时,每抽一发有p/2的概率抽到当期5星,有p/2的概率抽到常驻5星,其余的1一p概率不出5星。当抽到常驻5星后,触发了大保底机制,以后每抽一发有p的

来自 江苏省南京市 的网友 时间: 热度:°C 加入收藏 我要投稿 点赞()
以下是使用Java代码实现上述算法的示例:

```java
import java.util.Random;

public class GachaAlgorithm {
public static void main(String[] args) {
double p = 0.5; // 抽中5星的概率p
int count = simulateGacha(p);
System.out.println("抽卡次数:" + count);
}

public static int simulateGacha(double p) {
Random random = new Random();
int count = 0;
boolean isGrandGuaranteeTriggered = false; // 大保底机制是否触发

while (true) {
count++;

if (count == 90) {
return count; // 连续89抽未出5星,下一抽必出5星
}

if (isGrandGuaranteeTriggered) {
if (random.nextDouble() < p) {
return count; // 已触发大保底机制,100%概率抽到当期5星
}
} else {
double randomValue = random.nextDouble();
if (randomValue < p / 2) {
return count; // 1/2概率抽到当期5星
} else if (randomValue < p) {
isGrandGuaranteeTriggered = true; // 触发大保底机制
}
}
}
}
}
```

这段代码模拟了抽卡的过程,使用了`Random`类生成随机数来模拟抽卡的概率。`simulateGacha`方法接受一个概率值`p`作为参数,返回抽卡次数。

在循环中,首先判断是否已经连续89抽未出5星,如果是,则返回当前抽卡次数。然后根据是否触发了大保底机制来确定抽卡的逻辑。如果已触发大保底机制,则以概率`p`抽到当期5星;否则,以概率`p/2`抽到当期5星,以概率`p/2`抽到常驻5星,以概率`1-p`不出5星。

最后,输出抽卡次数即可得到答案。
221381
领取福利

微信扫码领取福利

微信扫码分享