java之DNF坑爹的强化

这两天在公司实习,用的是C#做软件的开发,没学过所以完全不感冒。。。

趁着中间有空写两个好玩的小程序打发一下时间。

是关于DNF的,里面的强化增幅一直觉得很坑,于是去查了概率,自己写一个模拟强化增幅的过程,来看看麻花藤究竟有多圈钱,这篇先上强化的,下一篇上增幅的。

基本思路

强化从0开始,一直到12,概率是不断变化的,上到10以上之后,失败了强化等级会减4。

所以大致是这样的:

1.回车,开始

2.满足概率,则level+1

3.10之前,不满则概率,则level不变

4.到10,之后,如果不满足概率,则level-4

至于概率方面,我采用的是在0到99内生成一个随机数,如果随机数能落在对应的概率范围内,则视为成功。

下面上代码

package com.wjt;

import java.util.Random;
import java.util.Scanner;

public class qianghua {
	
	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
	    int gl=0;
	    int level=0;
	    int s11=0;            //上11的计数器
	    int s12=0;            //上12的计数器
		Random random = new Random();
		int i = 0;
		while(true){
		switch(level) {            //每个等级的强化概率
			case 0:gl=100;break;
			case 1:gl=100;break;
			case 2:gl=100;break;
			case 3:gl=95;break;
			case 4:gl=90;break;
			case 5:gl=80;break;
			case 6:gl=60;break;
			case 7:gl=80;break;
			case 8:gl=90;break;
			case 9:gl=50;break;
			case 10:gl=26;break;
			case 11:gl=18;break;
		}
			if(level==12) {
				System.out.println("强化12成功!");
				System.out.println("上11失败了"+s11+"次");
				System.out.println("上12失败了"+s12+"次");
				break;
			}
		
			if(i>=0&&i<=gl) {
				level++;
				i=random.nextInt(99);     //生成随机数在范围内匹配
				new Scanner(System.in).nextLine();
				System.out.println("强化"+level+"成功!!!");
				continue;
				
			}else{
				if(0<=level&&level<10) {
					int a=level+1;
					s11++;
					i=random.nextInt(99);
					new Scanner(System.in).nextLine();
					System.out.println("强化"+a+"失败......");
					continue;
				}else{
					int b=level+1;					
					i=random.nextInt(99);
					s12++;
					new Scanner(System.in).nextLine();	//需要按一下空格输出一次时用这个代码
					System.out.println("强化"+b+"失败......");
					level=level-4;
					continue;
				}
							
			}
		}	
	}
}

中间遇到过几个问题,其一就是随机数的生成,要在每次匹配(强化)时,无论成功失败,都要刷新,也就是重新生成一个,否则会出现到一定概率无限失败的情况。还有就是一些小问题了,比如while加入后何时break,何时continue,还有成功与失败后结果的细分。

两个月之后重拾java写写小程序还是蛮有意思的。尤其是看到这个概率是如此低之后。。。

这是一个基本的 DNF 强化代码的 Java 实现,你可以根据自己的需求进行修改: ``` import java.util.Scanner; public class DNFStrengthening { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.print("请输入初始装备等级:"); int level = sc.nextInt(); System.out.print("请输入升级石数量:"); int stoneNum = sc.nextInt(); int successCount = 0; int failCount = 0; for (int i = 0; i < stoneNum; i++) { int rand = (int) (Math.random() * 100); if (rand < getSuccessRate(level)) { level++; successCount++; } else { level--; failCount++; } if (level >= 12) { System.out.println("恭喜你,装备强化成功!"); break; } else if (level < 0) { System.out.println("很遗憾,装备强化失败!"); break; } System.out.println("第" + (i+1) + "次强化结果:等级 " + level); } System.out.println("强化次数:" + stoneNum + ",成功次数:" + successCount + ",失败次数:" + failCount); } // 计算强化成功率 public static int getSuccessRate(int level) { switch (level) { case 0: return 100; case 1: return 95; case 2: return 90; case 3: return 85; case 4: return 80; case 5: return 75; case 6: return 70; case 7: return 65; case 8: return 60; case 9: return 55; case 10: return 50; case 11: return 45; default: return 0; } } } ``` 上述代码实现了一个 DNF 强化系统,其中 `getSuccessRate` 方法用来计算当前等级的强化成功率,`main` 方法中通过循环模拟了多次强化,直到装备强化成功或失败,同时记录了成功次数和失败次数。你可以在此基础上进行扩展,例如加入升级石的概率、强化成功后属性提升等等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值