Java实现简单双色球摇奖功能过程解析
时间:2021-06-17 09:19:28|栏目:JAVA代码|点击: 次
这篇文章主要介绍了Java实现简单双色球摇奖功能过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
双色球:从1-33号球中选取6个红球,且红球不重复
从1-16号球中选取一个篮球
话不多说 上代码~~~
package Javaee;
import java.util.Arrays;
import java.util.Random;
public class DoubleChromosphere {
public static void main(String[] args) {
//定义红球池
int[] redpool = new int[33];
//添加红球数字
for (int i = 0; i < redpool.length; i++) {
redpool[i] = i + 1;
}
//定义篮球池
int[] bluepool=new int[16];
for (int j = 0; j < bluepool.length; j++) {
bluepool[j] = j + 1;
}
//定义被选中的红球
int[] redballs =new int[6];
int x;
A: for (int i = 0; i < redballs.length; i++) {
x = new Random().nextint(33);
for (int j = 0; j <= i; j++) {
//去重过程
//判断当前循环取出的红球是否跟前几次取出的一样
//如果一样 大循环A向后退一次,重新取出红球
if (redballs[j] == redpool[x]) {
i--;
continue A;
}
}
//如果不一样,则把取出的红球池中取出的红球放入红球数组中
redballs[i] = redpool[x];
}
//取出篮球
int a = bluepool[new Random().nextint(16)];
//利用冒泡排序对红球进行排序
int temp;
for (int i = 0; i < redballs.length-1; i++) {
for (int j = 0; j < redballs.length-i-1; j++) {
if (redballs[j]>redballs[j+1]) {
temp=redballs[j+1];
redballs[j+1]=redballs[j];
redballs[j]=temp;
}
}
}
System.out.println("红球为:" + Arrays.toString(redballs));
System.out.println("蓝球为:" +a);
}
}
关键问题在于去除重复的红球,使用i--和对continue对数据进行去重,主要在于理解返回上一次循环和continue跳过此次循环重新赋值
上一篇:springboot接入cachecloud redis示例实践
栏 目:JAVA代码
本文标题:Java实现简单双色球摇奖功能过程解析
本文地址:http://www.codeinn.net/misctech/143647.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




