通过剔除抽中的号码来模拟彩票抽奖算法
//首先初始化红号和蓝号
int[] red = new int[33];
int[] blue = new int[16];
for(int i=0;i<33;i++){
red[i] = i+1;
}
for(int i=0;i<16;i++){
blue[i] = i+1;
}
StringBuffer sb = new StringBuffer();
String redNum ="";
sb.append("red:");
for(int i=32;i>2;i--){
Random rd = new Random();
int redRandom = rd.nextInt(i)+1;
sb.append(red[redRandom-1]+",");
//用数组的末尾来置换当前被抽中的球
red[redRandom-1] = red[red.length-1];
//重新赋值数组,去除末尾数字,来达到去除抽中球的目的
red = Arrays.copyOf(red,red.length-1);
//对得到的新数组进行重新排序,使模拟结果更加准确(这里没有绝对的准确)
Arrays.sort(red);
//System.out.println(Arrays.toString(red));
//因为我们只需要取6个红号,所以这里我们在取到6个数字的时候就停止
if(i<28){
break;
}
}
if(sb.toString().endsWith(",")){
redNum = sb.toString().substring(0,sb.toString().length()-1);
}
//蓝号的取法就很简单了,只需要从1-16里随便取一个即可
int blueNum = 0;
Random blueRd = new Random();
blueNum = blueRd.nextInt(15)+1;
System.out.println(redNum);
System.out.println("blue:"+blueNum);