【Java】抽奖系统———保姆学习教程

这篇具有很好参考价值的文章主要介绍了【Java】抽奖系统———保姆学习教程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

 一、抽奖系统介绍

 二、代码实现

1、随机生成中奖号码

1.1、中奖号码createNumber方法

 1.2、控制判断contains方法

2、用户输入中奖号码

3、判断中奖情况

3.1、判断奖项isWin方法 

三、完整代码


 一、抽奖系统介绍

抽奖的号码由6个红色球号码和1个蓝色球号码组成。红色球号码从1-33中选择,不允许重复,蓝色球号码从1-16中选择。红色球只看值,不看顺序。

java 抽奖系统,开发语言,java,intellij-idea,c语言,c++

注:我们这里规定一等奖为1000万,二等奖为30万,其他与表中一致。

 二、代码实现

1、随机生成中奖号码

1.1、中奖号码createNumber方法

创建一个长度为7的数组存放中奖号码,其中前6个为红球,最后1个为蓝球。

需要注意的是,for循环中,需要把i++放在if判断语句中,当数字重复时不执行i++语句,只有录入成功才进行++操作。

    public static int[] createNumber() {
        int[] arr = new int[7];
        Random r = new Random();
        //生成红球号码
        for (int i = 0; i < 6; ) {
            int redNumber = r.nextInt(33) + 1;
            if (contains(arr, redNumber)) {
                arr[i] = redNumber;
                i++;
            }
        }

        //生成蓝球号码
        int blueNumber = r.nextInt(16) + 1;
        arr[6] = blueNumber;

        return arr;
    }
 1.2、控制判断contains方法

 当数组arr中有num则返回false,没有则返回true。

    public static boolean contains(int[] arr, int num) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == num) {
                return false;
            }
        }
        return true;
    }

2、用户输入中奖号码

同样创建一个长度为7的数组,利用键盘录入用户输入号码。同样i++需要放入if判断语句中,当录入成功再进行++操作。

public static int[] userInputNumber() {
        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) {
                if (contains(arr, redNumber)) {
                    arr[i] = redNumber;
                    i++;
                } else {
                    System.out.println("当前红球号码已存在,请重新输入");
                }

            } else {
                System.out.println("当前红球号码超出范围");
            }
        }
        //输入蓝球号码
        while (true) {
            System.out.println("请输入蓝球号码");
            int blueNumber = sc.nextInt();
            if (blueNumber >= 1 && blueNumber <= 16) {
                arr[arr.length - 1] = blueNumber;
                break;
            } else {
                System.out.println("当前蓝球号码超出范围");
            }
        }
        return arr;
    }

3、判断中奖情况

 定义redCount和blueCount存放相同球的个数,写for循环时需要注意红球的范围。

    public static void main(String[] args) {
        //随机生成中奖号码
        int[] arr = createNumber();

        //用户输入中奖号码
        int[] userArr = userInputNumber();

        //判断中奖情况
        int redCount = 0;
        int blueCount = 0;
        for (int i = 0; i < userArr.length - 1; i++) {
            int redNumber = userArr[i];
            for (int j = 0; j < arr.length - 1; j++) {
                if (redNumber == arr[j]) {
                    redCount++;
                    break;
                }
            }
        }

        int blueNumber = userArr[userArr.length - 1];
        if (blueNumber == arr[arr.length - 1]) {
            blueCount++;
        }

        int winNum = isWin(redCount, blueCount);
        switch (winNum) {
            case 1 -> System.out.println("恭喜你,中奖1000万");
            case 2 -> System.out.println("恭喜你,中奖30万");
            case 3 -> System.out.println("恭喜你,中奖3000元");
            case 4 -> System.out.println("恭喜你,中奖200元");
            case 5 -> System.out.println("恭喜你,中奖10元");
            case 6 -> System.out.println("恭喜你,中奖5元");
            default -> System.out.println("非常遗憾,没有中奖");
        }


    }
3.1、判断奖项isWin方法 

 用于判断是否中奖以及中几等奖的函数,几等奖对应返回数字几,并在main中用switch判断。

    public static int isWin(int red, int blue) {
        if (red == 6 && blue == 1)
            return 1;
        else if (red == 6 && blue == 0)
            return 2;
        else if (red == 5 && blue == 1)
            return 3;
        else if ((red == 5 && blue == 0) || (red == 4 && blue == 1))
            return 4;
        else if ((red == 4 && blue == 0) || (red == 3 && blue == 1))
            return 5;
        else if ((red == 2 && blue == 1) || (red == 1 && blue == 1) || (red == 0 && blue == 1))
            return 6;
        else
            return 7;
    }

三、完整代码

import java.util.Random;
import java.util.Scanner;

public class test7 {
    public static void main(String[] args) {
        //随机生成中奖号码
        int[] arr = createNumber();

        //用户输入中奖号码
        int[] userArr = userInputNumber();

        //判断中奖情况
        int redCount = 0;
        int blueCount = 0;
        for (int i = 0; i < userArr.length - 1; i++) {
            int redNumber = userArr[i];
            for (int j = 0; j < arr.length - 1; j++) {
                if (redNumber == arr[j]) {
                    redCount++;
                    break;
                }
            }
        }

        int blueNumber = userArr[userArr.length - 1];
        if (blueNumber == arr[arr.length - 1]) {
            blueCount++;
        }

        int winNum = isWin(redCount, blueCount);
        switch (winNum) {
            case 1 -> System.out.println("恭喜你,中奖1000万");
            case 2 -> System.out.println("恭喜你,中奖30万");
            case 3 -> System.out.println("恭喜你,中奖3000元");
            case 4 -> System.out.println("恭喜你,中奖200元");
            case 5 -> System.out.println("恭喜你,中奖10元");
            case 6 -> System.out.println("恭喜你,中奖5元");
            default -> System.out.println("非常遗憾,没有中奖");
        }


    }

    public static int isWin(int red, int blue) {
        if (red == 6 && blue == 1)
            return 1;
        else if (red == 6 && blue == 0)
            return 2;
        else if (red == 5 && blue == 1)
            return 3;
        else if ((red == 5 && blue == 0) || (red == 4 && blue == 1))
            return 4;
        else if ((red == 4 && blue == 0) || (red == 3 && blue == 1))
            return 5;
        else if ((red == 2 && blue == 1) || (red == 1 && blue == 1) || (red == 0 && blue == 1))
            return 6;
        else
            return 7;
    }

    public static int[] userInputNumber() {
        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) {
                if (contains(arr, redNumber)) {
                    arr[i] = redNumber;
                    i++;
                } else {
                    System.out.println("当前红球号码已存在,请重新输入");
                }

            } else {
                System.out.println("当前红球号码超出范围");
            }
        }
        while (true) {
            System.out.println("请输入蓝球号码");
            int blueNumber = sc.nextInt();
            if (blueNumber >= 1 && blueNumber <= 16) {
                arr[arr.length - 1] = blueNumber;
                break;
            } else {
                System.out.println("当前蓝球号码超出范围");
            }
        }
        return arr;
    }

    public static int[] createNumber() {
        int[] arr = new int[7];
        Random r = new Random();
        for (int i = 0; i < 6; ) {
            int redNumber = r.nextInt(33) + 1;
            if (contains(arr, redNumber)) {
                arr[i] = redNumber;
                i++;
            }
        }
        int blueNumber = r.nextInt(16) + 1;
        arr[6] = blueNumber;

        return arr;
    }

    public static boolean contains(int[] arr, int num) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == num) {
                return false;
            }
        }
        return true;
    }
}

此次双色球彩票系统的内容就到此为止了,相信大家也能够做出属于自己的双色球彩票系统,这个系统最重要的是代码思维而不是代码本身,理解代码思维能够得到更大的提升。

如果觉得作者写的不错,求给作者一个大大的点赞支持一下,你们的支持是我更新的最大动力!文章来源地址https://www.toymoban.com/news/detail-725985.html

到了这里,关于【Java】抽奖系统———保姆学习教程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Java基础教程】Java学习路线攻略导图——史诗级别的细粒度归纳 ~

    🍺🍺 各位读者朋友大家好!得益于各位朋友的支持和关注,我的专栏《Java基础教程》 至今已经更新完毕,我们一起探索了Java语言的许多核心概念和重要特性。在过去的文章中,我们 一共涉及了入门知识介绍、编程基础概念、面向对象OOP、包及访问控制权限、异常处理篇、

    2024年02月14日
    浏览(53)
  • Midjourney学习系列之一 —— 保姆级入门教程

    继ChatGPT之后,AI绘图网站Midjourney也已经火出圈了。鉴于其强大的绘图能力和极低的使用门槛,Midjourney已经在事实上被各行各业的人作为辅助工具了,更重要的是,它绝对是一个非常理想的学习AI技术的引路人。 因此我在文章《一文了解AI绘图所有,含福利》中呼吁,每一个大

    2024年02月11日
    浏览(49)
  • 【学习笔记】上传代码到GitHub(保姆级教程)

    首先进入GitHub官网 选择右上角的 sign up 进入登录页面,等待动画加载完成出现输入Email 继续输入密码 继续下一步按照提示输入就好了 注册好账号我们可以进入下一步了 找到Git官网,进入主页,点击 Download 进入到下载页面 进入到下载页面可以看到有四个下载选择 分别是应用和便

    2024年02月08日
    浏览(46)
  • 【Java基础教程】Java学习路线攻略导图——史诗级别的细粒度归纳,持续更新中 ~

    🍺🍺 各位读者朋友大家好!得益于各位朋友的支持和关注,我的专栏《Java基础教程》 至今已经更新完毕,我们一起探索了Java语言的许多核心概念和重要特性。在过去的文章中,我们 一共涉及了入门知识介绍、编程基础概念、面向对象OOP、包及访问控制权限、异常处理篇、

    2024年02月16日
    浏览(44)
  • 【MySQL】MySQL事务保姆级教程(适合MySQL初学者学习)

    🧑‍💻作者名称:DaenCode 🎤作者简介:啥技术都喜欢捣鼓捣鼓,喜欢分享技术、经验、生活。 😎人生感悟:尝尽人生百味,方知世间冷暖。 📖所属专栏:重温MySQL 无论是在校招、社招,亦或者大学计算机专业、软件工程等相关面试或者考试中,MySQL事务的相关知识都是必

    2024年02月16日
    浏览(82)
  • 【window环境】Python安装与深度学习环境(tensorflow)配置保姆教程

    此贴主要记录window环境下,python安装、配置python环境及tensorflow(GPU、CPU)的配置。初学者记录贴,如内容有误,还请各位大佬指出来。 (1)访问Anaconda官网( https://docs.conda.io/en/latest/miniconda.html ),点击所需版本的下载链接。 (例如: https://repo.anaconda.com/miniconda/Miniconda3-

    2024年02月02日
    浏览(61)
  • 【云计算学习】open stack云平台安装部署(一)(小白手把手教会、保姆级教程)

    1.安装centos7虚拟机 这里我们使用的镜像文件为 CentOS-7-x86_64-DVD-2009 ,我们仅需配置 controller 节点,再将 controller 配置完成后直接克隆一台配置为 compute 节点。 2.为centos7虚拟机添加双网卡 点击 编辑此虚拟机设置 ,在下方找到 添加 按钮,点击添加,为虚拟机添加一张网卡 3.修

    2024年01月21日
    浏览(50)
  • 关于安装李沐深度学习d2l包报错的解决办法(保姆教程)

    因为换了新电脑,所以环境都是从零开始配置,但是在安装李沐深度学习里常用的d2l包的时候,确实频繁报错。 这里总结一下我的报错原因,希望大家在遇到bug的时候能够从容面对。 在安装深度学习框架之前,请先检查你的计算机上是否有可用的GPU。 例如,你可以查看计算

    2024年02月03日
    浏览(54)
  • Android JNI开发从0到1,java调C,C调Java,保姆级教程详解

    前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下\\\"通俗易懂,风趣幽默\\\",感觉非常有意思,忍不住分享一下给大家。 👉点击跳转到教程 第一步首先配置Android studio的NDK开发环境,首先在Android studio中下载NDK包 第二步在local.properties文件中,配置对应的NDK路径 第三

    2024年02月12日
    浏览(37)
  • Zookeeper篇——深入认识和学习Zookeeper节点-Znode,涵盖概念以及详细操作节点命令,保姆级教程,超详细、超全面!!!

    Zookeeper是一个分布式的协调服务,它通过维护一个分层的数据结构来存储和管理数据。这个数据结构被称为znode节点。每个znode节点在Zookeeper的命名空间中都有一个唯一的路径,类似于文件系统中的路径。 Zookeeper中的znode节点有以下几种类型: 永久节点(Persistent znode):永久

    2024年02月03日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包