//规则简介:中奖号码共7位,由前6位的红色球数字和最后1位蓝色球数字组成 //红色球号码在1-33中选择,抽出不放回(不重复),蓝色球号码在1-16中选择(可以与前面的红色球号码重复),前六位红色球的顺序与中奖无关,例如中奖号码为1 2 3 4 5 6,用户猜测的为6 5 4 3 2 1,也为6个红色球全猜中
import java.util.Random;
import java.util.Scanner;
public class 模拟双色球 {
public static void main(String[] args) {
//1.生成双色球号码
int[] arr = 存储号码();
//若想查看系统生成的号码,可以把下面的两行代码加进去,以便测试用
/*for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+" ");
}*/
//2.用户输入自己猜测的彩票号码
int[] userArr = 猜测号码();
//3.判断红球和蓝球分别猜中了几个
//两种颜色的球初始值都设为0
int redCount = 0;
int blueCount = 0;
//判断红球中奖个数,与位置无关,只与是否存在有关
for (int i = 0; i < userArr.length - 1; i++) {
for (int j = 0; j < arr.length - 1; j++) {
if (userArr[i] == arr[j]) {
redCount++;
break;//如果找到了,后面的数字就没必要比较了,直接跳出内循环,继续判断下一个红球数字是否中奖
}
}
}
//判断蓝球中奖个数
if (userArr[userArr.length - 1] == arr[arr.length - 1]) {
blueCount++;
}
//4.根据红球和蓝球的中奖个数,判断对应几等奖
if (redCount == 6 && blueCount == 1) {
System.out.println("恭喜你中了一等奖,奖金1000w元");
} else if (redCount == 6 && blueCount == 0) {
System.out.println("恭喜你中了二等奖,奖金500w元");
} else if (redCount == 5 && blueCount == 1) {
System.out.println("恭喜你中了三等奖,奖金3000元");
} else if ((redCount == 5 && blueCount == 0) || (redCount == 4 && blueCount == 1)) {
System.out.println("恭喜你中了四等奖,奖金200元");
} else if ((redCount == 4 && blueCount == 0) || (redCount == 3 && blueCount == 1)) {
System.out.println("恭喜你中了五等奖,奖金10元");
} else if ((redCount == 2 && blueCount == 1) || (redCount == 1 && blueCount == 1) || (redCount == 0 && blueCount == 1)) {
System.out.println("恭喜你中了六等奖,奖金5元");
} else {
System.out.println("谢谢惠顾");
}
}
//定义方法,存储系统生成的中奖号码
public static int[] 存储号码() {
//定义数组
int[] arr = new int[7];//长度为7,6个红色球,1个蓝色球
//生成范围内的随机数,并存储到数组中
Random r = new Random();
//随机生成红球号码
for (int i = 0; i < 6; ) {
int redNumber = r.nextInt(33) + 1;
//由于红色球数字不允许重复,所以需要判断当前数字在数组中是否存在
boolean flag = 判断当前数字是否存在(arr, redNumber);
if (flag == false) {
//把当前红球数字添加到数组中
arr[i] = redNumber;
i++;
}
}
//随机生成蓝球号码并添加到数组中
int blueNumber = r.nextInt(16) + 1;
arr[6] = blueNumber;
//红球蓝球都ok之后,把arr数组返回到main主方法中
return arr;
}
//定义方法,记录用户猜测的中奖号码
public static int[] 猜测号码() {
//定义数组
int[] arr = new int[7];
//键盘录入
Scanner sc = new Scanner(System.in);
//输入红球号码
for (int i = 0; i < 6; ) {
System.out.println("请输入第" + (i + 1) + "个红球号码");
int redNumber = sc.nextInt();
//由于红色球数字不允许重复,所以需要判断当前数字在数组中是否存在
if (redNumber >= 1 && redNumber <= 33) {
boolean flag = 判断当前数字是否存在(arr, redNumber);
if (flag == false) {//说明当前数字并未重复,可以存到数组当中
arr[i] = redNumber;
i++;
} else {
System.out.println("当前数字已存在,请重新输入");
}
} else {
System.out.println("当前红球数字超出范围,请正确输入");
}
}
//输入蓝球号码
System.out.println("请输入蓝球号码");
while (true) {
int blueNumber = sc.nextInt();
if (blueNumber >= 1 && blueNumber <= 16) {
arr[6] = blueNumber;
break;
} else {
System.out.println("当前蓝球号码超出范围,请正确输入");
}
}
return arr;
}
//定义方法,判断当前数字在数组中是否存在
public static boolean 判断当前数字是否存在(int[] arr, int number) {
for (int i = 0; i < arr.length; i++) {
if (arr[i] == number) {
return true;
}
}
return false;
}
}
结果演示:
1.全部猜中
2.一个也没猜中
当然了,还是第二种情况比较真实