1、随机一组中奖号码

中奖号码由6个红球和1个篮球组成(注意:6个红球要求不能重复)。 可以定义方法用于返回一组中奖号码(7个数据),返回的形式是一个整型数组。

2、用户输入一组号码,与随机中奖号码进行比对,根据双色球中奖规则进行开奖。

3、主要方法:数组,循环语句,分支语句,短路逻辑运算符等。


import java.util.Random;
import java.util.Scanner;/**需求:双色球模拟*/
public class Test8 {public static void main(String[] args) {// 1、随机6个红球号码(1-33,不能重复),随机一个蓝球号码(1-16),可以采用数组装起来作为中奖号码int[] luckNumbers = createLuckNumber();// printArray(luckNumbers);// 2、录入用户选中的号码int[] userNumbers = userInputNumbers();// 3、判断中奖情况judge(luckNumbers, userNumbers);}public static void judge(int[] luckNumbers, int[] userNumbers ){// 判断是否中奖了。// luckNumbers = [12, 23, 8, 16, 15, 32,   9]// userNumbers = [23, 13, 18, 6, 8, 33,   10]// 1、定义2个变量分别存储红球命中的个数,以及蓝球命中的个数。int redHitNumbers = 0;int blueHitNumbers = 0;// 2、判断红球命中了几个,开始统计for (int i = 0; i < userNumbers.length - 1; i++) {for (int j = 0; j < luckNumbers.length - 1; j++) {// 每次找到了相等了,意味着当前号码命中了if(userNumbers[i] == luckNumbers[j]){redHitNumbers ++ ;break;}}}// 蓝球号码是否命中了blueHitNumbers = luckNumbers[6] == userNumbers[6] ? 1 : 0;System.out.println("中奖号码是:"  );printArray(luckNumbers);System.out.println("您投注号码是:"  );printArray(userNumbers);System.out.println("您命中了几个红球:" + redHitNumbers);System.out.println("您是否命中蓝球:" + ( blueHitNumbers == 1 ? "是": "否" ) );// 判断中奖情况了if(blueHitNumbers == 1 && redHitNumbers < 3){System.out.println("恭喜您,中了5元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 3|| blueHitNumbers == 0 && redHitNumbers == 4){System.out.println("恭喜您,中了10元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 4|| blueHitNumbers == 0 && redHitNumbers == 5){System.out.println("恭喜您,中了200元!");}else if(blueHitNumbers == 1 && redHitNumbers == 5){System.out.println("恭喜您,中了3000元大奖!");}else if(blueHitNumbers == 0 && redHitNumbers == 6){System.out.println("恭喜您,中了500万超级大奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 6){System.out.println("恭喜您,中了1000万巨奖!");}else {System.out.println("感谢您为福利事业做出的突出贡献!!");}}public static int[] userInputNumbers(){// a、动态初始化一个数组,长度为7int[] numbers = new int[7];Scanner sc = new Scanner(System.in);for (int i = 0; i < numbers.length - 1; i++) {System.out.println("请您输入第"+(i + 1)+"个红球号码(1-33、不重复):");int data = sc.nextInt();numbers[i] = data;}// b、录入一个蓝球号码System.out.println("请您输入一个蓝球号码(1-16):");int data = sc.nextInt();numbers[numbers.length - 1] = data;return numbers;}public static void printArray(int[] arr){for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");}System.out.println();}public static int[] createLuckNumber(){// a、定义一个动态初始化的数组,存储7个数字int[] numbers = new int[7];  // [12, 23, 0, 0, 0, 0, | 0]//                                   i// b、遍历数组,为每个位置生成对应的号码。(注意:遍历前6个位置,生成6个不重复的红球号码,范围是1-33)Random r = new Random();for (int i = 0; i < numbers.length - 1; i++) {// 为当前位置找出一个不重复的1-33之间的数字while (true) {int data = r.nextInt(33) + 1; // 1-33 ====>  (0-32) + 1// c、注意:必须判断当前随机的这个号码之前是否出现过,出现过要重新随机一个,直到不重复为止,才可以存入数组中去。// 定义一个flag变量,默认认为data是没有重复的boolean flag = true;for (int j = 0; j < i; j++) {if(numbers[j] == data) {// data当前这个数据之前出现过,不能用flag = false;break;}}if(flag) {// data这个数据之前没有出现过,可以使用了numbers[i] = data;break;}}}// d、为第7个位置生成一个1-16的号码作为蓝球号码numbers[numbers.length - 1] = r.nextInt(16) + 1;return numbers;}
}

Java——黑马程序员双色球案例相关推荐

  1. 黑马程序员双色球系统开发源码

    package com.zhou;import java.util.Random; import java.util.Scanner;public class ShuangSeQiu {public ...

  2. java黑马程序员4-1图书购买系统案例代码

    package jensenyao123; //图书类 public class Book {private int id;//图书编号private String name;//图书名称privat ...

  3. 零基础JAVA——黑马程序员课程笔记

    视频地址:点击访问 (我这里开发工具有时候用eclipse有时候用IDEA,看每个人的习惯) (文中代码部分不会和老师讲的一模一样,因为我都是在看到老师给的案例后自己尝试写的,推荐大家这样做,可以帮助 ...

  4. 【JAVA黑马程序员笔记】四 P314到P384(特殊流、多线程编程、网络编程模块、lambda表达式、接口组成更新、方法引用、函数式接口)

    P314-315 字节/符打印流 PrintStream ps = new PrintStream("test.txt");//使用字节输出流的方法ps.write(97);// ...

  5. JAVA黑马程序员day7(面向对象)

    类和对象的基本概念 封装 Private权限修饰符 this关键字 构造方法: 标准的javaBean类 插件PTG可以一键生成javabean标准类 成员变量和局部变量 练习:文字版格斗游戏 Rol ...

  6. Java黑马程序员:文字版格斗游戏

    package 练习包;import java.lang.reflect.Member; import java.lang.reflect.Method;public class Day01 {pub ...

  7. 【JAVA黑马程序员笔记】三P233-P312(List、Set、比较器、泛型、Map、File、IO流...)

    P233 数据结构 栈:数据进入栈模型叫做压栈,数据离开栈模型为弹栈.栈是后进先出的模型. 队列:数据从后端进入队列模型的过程叫做入队列,离开队列的过程叫出队列.队列是先进先出的模型. 数组:查询数组 ...

  8. 黑马程序员C++ 案例四 机房预约系统

    源文件 机房预约系统.cpp #include<iostream> using namespace std; #include"identity.h" #include ...

  9. 黑马程序员Java零基础视频教程_上部(P1-P80)

    黑马程序员Java零基础视频教程_上部(P1-P80) 1. Java入门 1.1 Java学习介绍 1.2 Java人机交互 1.2.1 常用CMD命令 2. Java基础学习 2.1 Java入门 ...

最新文章

  1. Tiny4412 Android5.0 定制:编译生成img后如何删除原厂的apk
  2. Linux 的多线程编程的高效开发经验
  3. 错误消息 This computer doesn‘t have VT-X/AMD-v enabled
  4. 协议转换器是怎么分类的?主要有哪些类别?
  5. (二)Cypher语言常用方法举例
  6. 【数学】Element Swapping
  7. SecurityManager篇
  8. Win8 DirectX 开发问题总结(一)
  9. 经典C语言编程100例——题目+答案代码(1-10)
  10. 2014年天津市第一批科技计划项目
  11. 机械制造技术基础【3】
  12. Unity 跳转第三方App
  13. 量子计算机九章骗局,200秒完成6亿年工作,量子计算机“九章”到底有多牛?...
  14. 【Linux】一步一步学Linux系列教程汇总(更新中......)
  15. 既是老师又是师兄的临别箴言 .
  16. linux signal用法,Linux 信号 signal 用法详解及注意事项
  17. 如何实现在线文档?Vue+SpreadJS组合拳出击
  18. 一个棋牌游戏的服务端开发1
  19. strcpy、strncpy、strncpy_s和snprintf
  20. git clone 使用源仓库换行符风格

热门文章

  1. 2021年初级会计如何去学习?
  2. 按照下列给定步骤完成求累加和程序: 程序: MOV BX,1000 MOV CX,10 MOV AL,0 LOP: ADD AL,[BX] INC BX J: LOOP LOP INT
  3. 【51nod_3144】超级购物【期望】
  4. R语言绘图——Graphics包
  5. 不适定问题(Ill-posed problem)
  6. 消防报警名词解释--转自消防星
  7. python网易云听歌时长_Python爬虫实战:爬取小姐姐最近的听歌曲目
  8. 通电后第一次开机黑屏_为什么我的电脑第一次开机是黑屏,要开第二次才可以...
  9. 工控计算机系统,工控电脑装什么系统好
  10. 把声音画出来,会长成什么样?——HMM模型实例展示语音识别全流程