哈喽~大家好,好久没有更新了,也确实遇到了很多事,这篇开始恢复更新,喜欢的话,可以给个的三连,什么?你要白嫖?那可以给个免费的赞麻。
🥇个人主页:个人主页
🥈 系列专栏:【JAVASE开发】
🥉与这篇相关的文章:
【JAVA凝气】异常篇
【JAVA凝气】异常篇_程序猿追的博客-CSDN博客 Java测试、反射、注解 Java测试、反射、注解_java测试类注解_程序猿追的博客-CSDN博客 【JAVASE开发】带你零基础学JAVA项目(学生管理系统篇) 【JAVASE开发】带你零基础学JAVA项目(学生管理系统篇)_程序猿追的博客-CSDN博客
号外号外,我最近发现了一个非常棒的人工智能学习网站,它的内容通俗易懂,风趣幽默,让人印象深刻。我想和大家分享这个网站,点击链接即可访问。
目录
一、前言
二、效果演示
三、具体代码
四、到底夺少抽才能双金?
一、前言
本篇文章将会用Java模拟原神抽卡,先说结论, 再来分析。
在 [1,73] 抽时, 每次出五星角色的概率为 0.6% , 在 [74,90] 抽每次抽卡概率比上次高 6% 。
当获取到五星角色时, 有 50% 概率是UP角色, 若这次五星没有抽到UP角色, 下次五星角色必定是UP角色。五星角色保底为 90 抽, 五星UP角色保底为 180 抽。
4星物品(武器和角色)基础概率为5.1%,包括保底的概率为13%,最多10次保底4星物品(角色或者武器)。当获得4星物品时有50%的几率为UP角色。
角色池抽卡概率递增表
二、效果演示
三、具体代码
public static void ou(int a) {
if (a <= 10)
System.out.println("\33[93;1m终极无敌至尊欧皇!!\33[0m");
else if (a <= 30)
System.out.println("\33[93;1m大欧皇!\33[0m");
else if (a <= 50)
System.out.println("\33[95;1m欧皇\33[0m");
else if (a <= 70)
System.out.println("\33[94;1m欧非守恒\33[0m");
else if (a <= 80)
System.out.println("\33[91;1m非酋\33[0m");
else if (a <= 85)
System.out.println("\33[91;1m大非酋!\33[0m");
else if (a <= 90)
System.out.println("\33[91;1m终极无敌至尊非酋王!!\33[0m");
}
package com.YSCKXM;
import java.util.Scanner;
import java.util.Random;
public class Main {
public static void main(String[] args) {
Random r = new Random();
Scanner sc = new Scanner(System.in);
int a = 0, i = 0;
int jin = 0, zi = 0, P = 0, L = 0, jinCount = 0;
int ys = 0;
int sum = 0;
int[] logs = new int[200];
while (true) {
System.out.println("原石:" + ys);
System.out.println("请选择");
System.out.println("A-单抽");
System.out.println("B-十连");
System.out.println("C-氪648");
System.out.println("D-查询抽卡记录");
System.out.println("其它-退出");
char c = sc.next().charAt(0);
switch (c) {
case 'A':
if (ys >= 160) {
a = 1;
ys -= 160;
} else {
a = -2;
System.out.println("\33[91;1m原石不足,请充值!\33[0m");
}
break;
case 'B':
if (ys >= 1600) {
a = 10;
ys -= 1600;
} else {
a = -2;
System.out.println("\33[91;1m原石不足,请充值!\33[0m");
}
break;
case 'C':
a = -2;
ys += 6480;
System.out.println("\33[92;1m充值成功!\33[0m");
break;
case 'D':
a = -2;
if (logs[0] != 0) {
System.out.print("\33[96;1m抽卡记录:\33[0m");
for (i = 0; i < L; i++) {
sum += logs[i];
System.out.print(logs[i] + " ");
}
sum = sum / L;
System.out.println("");
System.out.println("\33[96;1m平均出金:\33[0m" + sum);
ou(sum);
} else
System.out.println("\33[37;1m暂未出金\33[0m");
break;
default:
return;
}
if (a == -2) continue;
for (i = 0; i < a; i++) {
int num1 = r.nextInt(1000) + 1;
int num2 = r.nextInt(1000) + 1;
if (jin >= 89 || (num1 > 0 && num1 <= 6 && jin <= 72) || ((num1 > 0 && num1 <= 6 + (jin - 72) * 60) && jin >= 73)) {
System.out.print("\33[93;1m金\33[0m ");
{
P = jin + 1;
logs[L] = P;
L++;
jinCount++;
jin = 0;
zi++;
}
} else if ((zi >= 9 || (num2 >= 1 && num2 <= 51 && zi <= 7) || (num2 >= 1 && num2 <= 561 && zi == 8))) {
System.out.print("\33[95;1m紫\33[0m ");
zi = 0;
jin++;
} else {
System.out.print("\33[94;1m蓝\33[0m ");
jin++;
zi++;
}
}
System.out.println(jin + "\33[37;1m抽未出金\33[0m");
if (P != 0) {
if (jinCount == 1)
System.out.println("\33[96;1m第\33[0m" + P + "\33[96;1m抽出金\33[0m");
else if (jinCount >= 1)
System.out.println(jinCount + "\33[93;1m连金\33[0m");
jinCount = 0;
ou(P);
P = 0;
}
}
}
}
四、到底夺少抽才能双金?
改一个分支条件,flag 是开关, 这时我们的原石数量是无限,循环一直抽下去。
else if (jinCount >= 1 && jin == 2 && P == 10)
{
System.out.println("第" + jinCount + "抽出了\33[93;1m连金\33[0m");
jinCount = 0;
P = 0;
flag = 1;
}
运行结果(仅供参考,具体以实际为准,反正我还没双金过,呜呜呜)
========================================分割线=================================2023-09-06 更新
好消息我也有双金了,坏消息是常驻出的
1200抽出的,感觉模拟双金概率还算挺准确的,后续会优化
不积跬步无以至千里,趁年轻,使劲拼,给未来的自己一个交代!向着明天更好的自己前进吧!文章来源:https://www.toymoban.com/news/detail-655895.html
文章来源地址https://www.toymoban.com/news/detail-655895.html
到了这里,关于用Java实现原神抽卡算法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!