ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Java实现双色球

2022-01-06 09:32:37  阅读:160  来源: 互联网

标签:双色球 Java 号码 红球 实现 System int array out


题目介绍

1.玩法介绍

“双色球”每注投注号码由 6 个红色球号码1 个蓝色球号码组成。红色球号码从 1~33 中选择,蓝色球号码从 1~16 中选择。 球的数字匹配数量和颜色决定了是否中奖。

2.中奖规则

在这里插入图片描述

3.要求

1.生成本期双色球中奖号码。(注意:1.生成的红球随机有序且不可重复 2.蓝球和红球的随机范围不同且篮球允许和红球重复)

2.用户两种产生数据方式
(1)自动生成。(机选)
(2)通过控制台输入竞猜号码。(自选)

3.记录红球、蓝球竞猜正确球的数量,并根据获奖条件输出竞猜结果和本期双色球号码。

分析

  1. 用数组来代表双色球的选号,数组大小为7,前6个元素表示红色球的号码,最后一个元素表示蓝色球的号码。
		int[] array = new int[7];    // 存储双色球的号码 前6个为红球 最后一个为蓝球

这里定义两个数组,一个表示用户的双色球号码,另一个表示中奖的双色球号码。

		int[] array = new int[7];    // 存储双色球的号码 前6个为红球 最后一个为蓝球
		int[] result;    // 中奖的双色球号码
  1. 定义两个计数器,分别记录红球,蓝球中奖的个数。
		int countRed = 0;    // 红色球中奖的个数
        int countBlue = 0;    // 蓝色球中奖个数片
  1. 利用switch进行分支操作,实现机选和自选
  2. 机选号码和中奖号码的生成用随机数自动生成,这里将部分重复内容写在了一个函数中。
    // 随机生成双色球方法
    public static int[] randomArray() {
        int[] array = new int[7];
        // 产生6个不同的随机数 表示6个红球
        for (int i = 0; i < 6; i++) {
            boolean flag = true;    // 定义一个标志,判断红球号码是否重复
            int randomNum = (int)(Math.random() * 33 + 1);    // 随机产生一个红球号码(1~33)
            // 遍历数组 只有红球要求号码各不相同故只需要遍历前6个号码
            for (int j = 0; j < 6; j++) {
                if (randomNum == array[j]) {    // 将数组中所有的号和新产生的随机号码比较
                    i--;    // 将i回退
                    flag = false;    // 表示重复
                    break;
                }
            }
            if (flag) {    // 若不重复
                array[i] = randomNum;    // 将随机产生的红球号码存放在array中
            }
        }
        array[6] = (int)(Math.random() * 16 + 1);    // 随机生成蓝球号码 1~16
        return array;
    }
  1. 红球需要升序排序,所以只需要对数组中前6个元素(共7个元素)进行排序即可,这里用的是冒泡排序。
	// 排序(从小到大) 冒泡
    public static int[] sort (int[] a) {
        // 只对前6个号码进行排序,故此处为a.length-2
        for (int i = 0; i < a.length-2; i++) {
            for (int j = 0; j < a.length-i-2; j++) {
                if (a[j] > a[j+1]) {
                    int temp = a[j];
                    a[j] = a[j+1];
                    a[j+1] = temp;
                }
            }
        }
        return a;
    }

活不多说上代码。

源代码

public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("============欢迎进入双色球机选系统(本期奖金500万)============");
        System.out.println("1:机选双色球\t\t\t2:自选双色球");
        int n = sc.nextInt();
        int[] array = new int[7];    // 存储双色球的号码 前6个为红球 最后一个为蓝球
        int[] result;    // 中奖的双色球号码
        int countRed = 0;    // 红色球中奖的个数
        int countBlue = 0;    // 蓝色球中奖个数
        switch(n) {
            case 1:    // 机选双色球
                // 随机生成双色球号码
                array = randomArray();
                // 对生成的红色球号码进行排序
                sort(array);
                // 输出机选结果
                System.out.print("机选红球号码:[");
                for (int i = 0; i < 6; i++) {
                    if (i != 5) {
                        System.out.print(array[i] + ", ");
                    } else {
                        System.out.println(array[i] + "]");
                    }
                }
                System.out.println("机选蓝球号码:[" + array[6] + "]");
                break;
            case 2:    // 自选双色球
                System.out.println("自选");
                System.out.println("请输入您选择的红球号码(1~33)");
                for (int i = 0; i < 6; i++) {
                    System.out.print("请输入第" + (i+1) + "个红球的号码:");
                    array[i] = sc.nextInt();
                }
                System.out.print("请输入蓝色球的号码(1~16):");
                array[6] = sc.nextInt();
                // 红色球排序
                sort(array);
                break;
            default:
                System.out.println("输入错误!");
                System.exit(0);
        }
        System.out.println("========================正在开奖请等待========================");
        // 随机生成中奖的号码
        result = randomArray();
        // 对生成的红色球中奖号码进行排序
        sort(result);
        // 输出中奖的号码
        System.out.print("本期中奖红球号码:[");
        for (int i = 0; i < 6; i++) {
            if (i != 5) {
                System.out.print(result[i] + ", ");
            } else {
                System.out.println(result[i] + "]");
            }
        }
        System.out.println("本期中奖蓝球号码:[" + result[6] + "]");
        // 统计红色球中奖个数
        for (int i = 0; i < 6; i++) {
            for (int j = 0; j < 6; j++) {
                if (array[i] == result[j]) {
                    countRed++;
                }
            }
        }
        if (array[6] == result[6]) {    // 统计蓝色球中奖个数
            countBlue++;
        }
        System.out.println("选6+1中"+ countRed + "+" + countBlue);
        // 判断是否中奖
        if (countRed <= 3 && countBlue == 0) {
            System.out.println("很遗憾您没有中奖 ╭(╯^╰)╮");
        } else if (countRed < 3 && countBlue == 1) {
            System.out.println("恭喜您中奖:六等奖! 5块钱!");
        } else if ((countRed ==3 && countBlue == 1) || (countRed == 4 && countBlue == 0)) {
            System.out.println("恭喜您中奖:五等奖! 10块钱!!");
        } else if ((countRed == 4 && countBlue == 1) || (countRed == 5 && countBlue == 0)) {
            System.out.println("恭喜您中奖:四等奖! 200元!!!");
        } else if (countRed == 5 && countBlue == 1) {
            System.out.println("恭喜您中奖:三等奖! 3000元!!!!");
        } else if (countRed == 6 && countBlue == 0) {
            System.out.println("恭喜您中奖:二等奖! "+ 500*0.3 +"万元w(゚Д゚)w!!!!!");
        } else {
            System.out.println("恭喜您中奖:一等奖! 500万元 (^o^) / w(゚Д゚)w!!!!!");
        }
    }

    // 随机生成双色球方法
    public static int[] randomArray() {
        int[] array = new int[7];
        // 产生6个不同的随机数 表示6个红球
        for (int i = 0; i < 6; i++) {
            boolean flag = true;    // 定义一个标志,判断红球号码是否重复
            int randomNum = (int)(Math.random() * 33 + 1);    // 随机产生一个红球号码(1~33)
            // 遍历数组 只有红球要求号码各不相同故只需要遍历前6个号码
            for (int j = 0; j < 6; j++) {
                if (randomNum == array[j]) {    // 将数组中所有的号和新产生的随机号码比较
                    i--;    // 将i回退
                    flag = false;    // 表示重复
                    break;
                }
            }
            if (flag) {    // 若不重复
                array[i] = randomNum;    // 将随机产生的红球号码存放在array中
            }
        }
        array[6] = (int)(Math.random() * 16 + 1);    // 随机生成蓝球号码 1~16
        return array;
    }

    // 排序(从小到大) 冒泡
    public static int[] sort (int[] a) {
        // 只对前6个号码进行排序,故此处为a.length-2
        for (int i = 0; i < a.length-2; i++) {
            for (int j = 0; j < a.length-i-2; j++) {
                if (a[j] > a[j+1]) {
                    int temp = a[j];
                    a[j] = a[j+1];
                    a[j+1] = temp;
                }
            }
        }
        return a;
    }

总结

这是学习中的一个小案例,作者还在努力学习中,如有考虑不周,请各路大神批评指正,共同学习。

标签:双色球,Java,号码,红球,实现,System,int,array,out
来源: https://blog.csdn.net/qq_45583486/article/details/122336097

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有