用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实现原神抽卡算法_第1张图片

 二、效果演示

用Java实现原神抽卡算法_第2张图片

 用Java实现原神抽卡算法_第3张图片

 用Java实现原神抽卡算法_第4张图片

 三、具体代码

    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;
                    }

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

用Java实现原神抽卡算法_第5张图片

用Java实现原神抽卡算法_第6张图片

用Java实现原神抽卡算法_第7张图片

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

你可能感兴趣的:(#,JAVASE开发,java,开发语言)