用Java实现原神抽卡算法

哈喽~大家好,好久没有更新了,也确实遇到了很多事,这篇开始恢复更新,喜欢的话,可以给个的三连,什么?你要白嫖?那可以给个免费的赞麻。

🥇个人主页:个人主页​​​​​

🥈 系列专栏:【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角色。

角色池抽卡概率递增表

二、效果演示

三、具体代码

java 复制代码
    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");
    }
java 复制代码
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 是开关, 这时我们的原石数量是无限,循环一直抽下去。

java 复制代码
                    else if (jinCount >= 1 && jin == 2 && P == 10)
                    {
                        System.out.println("第" + jinCount + "抽出了\33[93;1m连金\33[0m");
                        jinCount = 0;
                        P = 0;
                        flag = 1;
                    }

运行结果(仅供参考,具体以实际为准,反正我还没双金过,呜呜呜)

不积跬步无以至千里,趁年轻,使劲拼,给未来的自己一个交代!向着明天更好的自己前进吧!

相关推荐
时艰.9 小时前
java性能调优 — 高并发缓存一致性
java·开发语言·缓存
落花流水 丶9 小时前
Java 多线程完全指南
java
MSTcheng.9 小时前
【C++】C++智能指针
开发语言·c++·智能指针
无小道9 小时前
Qt——网络编程
开发语言·qt
wazmlp0018873699 小时前
第五次python作业
服务器·开发语言·python
云深处@9 小时前
【C++11】部分特性
开发语言·c++
尘缘浮梦9 小时前
websockets简单例子1
开发语言·python
jxy99989 小时前
mac mini 安装java JDK 17
java·开发语言·macos
独望漫天星辰9 小时前
C++ 树结构进阶:从工程化实现到 STL 底层与性能优化
开发语言·c++
biyezuopinvip9 小时前
基于Spring Boot的企业网盘的设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·企业网盘的设计与实现