福利彩票(数组版)

 题目要求:用户按照自己的想法输入1--31之间七个不相等的数,机器随机产生7个不相等的数作为开奖号码,然后比较两者的相等个数,全中一等奖,中6个二等奖,中5个,三等奖;

代码实现

package com.hundan04.demo01;
 ​
 import java.util.Arrays;
 import java.util.Random;
 import java.util.Scanner;
 ​
 /**
  * @author 混蛋
  * @create 2022/8/15  0:15
  * ===============================================
  * 1.随机产生1----31之间不相等的7个数
  * 2.用户输入1---31之间不想的7个数,
  * 3.两者比较确定相等的个数,
  * 4.判断相等的个数进而得到对应的奖项
  */
 public class Demo01Check7Random31 {
     public static void main(String[] args) {
         //1.获取随机产生的数组
         int[] randomAray = randomAray();
         //如果想作弊,请打开此行代码
 //        System.out.println(Arrays.toString(randomAray));
 ​
         //2.获取用户输入法人数的数组
         int[] userArray = userArray();
         System.out.println("你输入的号码为:"+Arrays.toString(userArray));
 ​
         System.out.println("本次开奖号码为:"+Arrays.toString(randomAray));
 ​
         //3.获取两个数组想等的个数
         int count = comparator(userArray, randomAray);
 ​
         //4.swith判断不停数字产生不同的奖项
         switch (count) {
             case 0:
                 System.out.println("0个,未中奖");
                 break;
             case 1:
                 System.out.println("一个,未中奖");
                 break;
             case 2:
                 System.out.println("二个,未中奖");
                 break;
             case 3:
                 System.out.println("三个,未中奖");
                 break;
             case 4:
                 System.out.println("四个,未中奖");
                 break;
             case 5:
                 System.out.println("五个,三等奖");
                 break;
             case 6:
                 System.out.println("六个,二等奖");
                 break;
             case 7:
                 System.out.println("七个,一等奖奖");
                 break;
         }
     }
 ​
     /**
      * 随机产生七个数的方法
      *
      * @return
      */
     public static int[] randomAray() {
         //1.定义一个数组,用于存放随机产生的数
         int[] randomArray = new int[7];
         //2.创建Random对象
         Random random = new Random();
         //3.循环7次,产生7个不想等的随机数,存入数组
         for (int i = 0; i < randomArray.length; i++) {
             //4.产生1---31之间的数
             int num = random.nextInt(31) + 1;
             //5.判断数组中舒服存在相等的的数,定义一个方法,用书输入的时候还要用
             if (isSave(randomArray, num)) {
                 //6.存在的话,循环次数恢复到原值
                 i--;
             } else {
                 //不存在,存入到数组
                 randomArray[i] = num;
             }
         }
         //返回得到的集合
         return randomArray;
     }
 ​
     /**
      * 用户输入的数的数组
      *
      * @return
      */
     public static int[] userArray() {
         //1.创建一个数组,用于存放用户输入的数
         int[] userArray = new int[7];
         //2.创建Scanner对象
         Scanner scanner = new Scanner(System.in);
         //3.循环输入7个不相等的数
         for (int i = 0; i < userArray.length; i++) {
             //4.提示用户输入数
             System.out.println("请输入第" + (i + 1) + "个数");
             int num = scanner.nextInt();
             //5.判断该数是否在1---31之间
             if (!(num >= 1 && num <= 31)) {
                 System.out.println("请输入1---31之间的数");
                 i--;
             } //6.判断输入的数是否存在
             else if (isSave(userArray, num)) {
                 //6.1存在,次数减1,提示重新输入
                 System.out.println("该数已存在,请重新输入");
                 i--;
             } else {
                 // 6.2不存在,存入数组
                 userArray[i] = num;
             }
         }
         //返回数组
         return userArray;
     }
 ​
     /**
      * 判断数组中是否有重重复的数
      *
      * @param array
      * @param key
      * @return
      */
     public static boolean isSave(int[] array, int key) {
         for (int i : array) {
             if (i == key) {
                 return true;
             }
         }
         return false;
     }
     
     /**
      * 比较两个数组的元素的想等的个数
      *
      * @param array01
      * @param array02
      * @return
      */
     public static int comparator(int[] array01, int[] array02) {
         //1.定义一个计数器,记录相等的个数
         int count = 0;
         //2.遍历一个数组,得到元素
         for (int key : array01) {
             //3/调用判断一个数组中是否包含一个数
             if (isSave(array02, key)) {
                 //3.1包含,count加1;
                 count++;
             }
         }
         return count;
     }
 }
 ​

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是福利彩票双色球Java的实现: ```java import java.util.Arrays; import java.util.Random; import java.util.Scanner; public class DoubleColorBall { public static void main(String[] args) { Scanner input = new Scanner(System.in); System.out.print("请输入您要购买的彩票注数:"); int n = input.nextInt(); int[][] tickets = new int[n][7]; for (int i = 0; i < n; i++) { System.out.println("请输入第" + (i + 1) + "注彩票的号码:"); for (int j = 0; j < 6; j++) { System.out.print("请输入第" + (j + 1) + "个红球号码(1-33):"); int redBall = input.nextInt(); while (redBall < 1 || redBall > 33) { System.out.print("输入有误,请重新输入第" + (j + 1) + "个红球号码(1-33):"); redBall = input.nextInt(); } tickets[i][j] = redBall; } System.out.print("请输入蓝球号码(1-16):"); int blueBall = input.nextInt(); while (blueBall < 1 || blueBall > 16) { System.out.print("输入有误,请重新输入蓝球号码(1-16):"); blueBall = input.nextInt(); } tickets[i][6] = blueBall; } System.out.println("您购买的彩票号码为:"); for (int i = 0; i < n; i++) { System.out.print("第" + (i + 1) + "注:"); for (int j = 0; j < 6; j++) { System.out.print(tickets[i][j] + " "); } System.out.println("蓝球:" + tickets[i][6]); } int[] result = getResult(); System.out.println("本期开奖号码为:" + Arrays.toString(Arrays.copyOf(result, 6)) + " 蓝球:" + result[6]); int totalMoney = n * 2; int totalPrize = 0; for (int i = 0; i < n; i++) { int prize = getPrize(tickets[i], result); totalPrize += prize; if (prize > 0) { System.out.println("第" + (i + 1) + "注彩票中奖了,中奖金额为:" + prize + "元"); } } System.out.println("您一共下注" + totalMoney + "元,累计中奖" + totalPrize + "元"); } public static int[] getResult() { int[] result = new int[7]; Random random = new Random(); for (int i = 0; i < 6; i++) { int redBall = random.nextInt(33) + 1; while (contains(result, redBall, i)) { redBall = random.nextInt(33) + 1; } result[i] = redBall; } Arrays.sort(result, 0, 6); int blueBall = random.nextInt(16) + 1; result[6] = blueBall; return result; } public static boolean contains(int[] array, int value, int length) { for (int i = 0; i < length; i++) { if (array[i] == value) { return true; } } return false; } public static int getPrize(int[] ticket, int[] result) { int redCount = 0; int blueCount = 0; for (int i = 0; i < 6; i++) { if (contains(result, ticket[i], 6)) { redCount++; } } if (ticket[6] == result[6]) { blueCount = 1; } if (redCount == 6 && blueCount == 1) { return 10000000; } else if (redCount == 6) { return 500000; } else if (redCount == 5 && blueCount == 1) { return 3000; } else if (redCount == 5 || (redCount == 4 && blueCount == 1)) { return 200; } else if (redCount == 4 || (redCount == 3 && blueCount == 1)) { return 10; } else if (blueCount == 1) { return 5; } else { return 0; } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值