package base;
import java.util.Arrays;
import java.util.Random;
/**
* 模拟双色球 从1~33个数中抽出不重复的6个数为红球,然后冲1~16中抽出1个数是蓝球
* @author Administrator
*
*/
public class lottery {
/**
* 测试产生10注双色球
* @param args
*/
public static void main(String[] args) {
lottery d = new lottery();
for (int i = 0; i < 10; i++) {
int[] ary = d.createRedball();
System.out.println(Arrays.toString(ary));
}
}
/**
* 随机产生6个不重复的并且按顺序排列的6个红球和最后一个放蓝球
* @return 6个红球
*/
public int[] createRedball() {
//用一个数组来存放33个红球
int[] redball = new int[33];
for (int i = 0; i < redball.length; i++) {
redball[i] = i + 1;// 1--33
}
//used表示已经出现过的红球
boolean[] used = new boolean[redball.length];
//dest数组 表示要存放得出的6个红球
int[] dest = new int[6];
Random r = new Random();
int index = 0;
//做完循环可以得出6个不重复的数字,并存放到dest数组
while (true) {
//通过随机产生一个数,然后通过下标就可以确定是哪个数字。
int num = r.nextInt(redball.length);// [0-33)
//如果这个数字没有出现过,那么就放到目标数组,如果一直执行,直到产生一个不重复的数字
if (!used[num]) {
dest[index++] = redball[num];
used[num] = true;
}
//装满最后一个的时候则推出循环
if (dest[dest.length - 1] != 0) {
break;
}
}
//排序
Arrays.sort(dest);
//排序后进行扩容
dest = Arrays.copyOf(dest, dest.length + 1);
// 把随机产生一个蓝球放到数组的最后一个位置
dest[dest.length - 1] = r.nextInt(16) + 1;// [1--16]
return dest;
}
}
双色球小程序 从1~33个数中抽出不重复的6个数为红球,然后从1~16中抽出1个数是蓝球
最新推荐文章于 2024-06-25 15:00:28 发布