java实现简单的抽奖游戏(数组学习)

java实现简单的抽奖游戏(数组学习)参考文章https://blog.csdn.net/zzq1992126/article/details/44118429参考书籍《java核心技术·卷一:基础知识》代码//程序目标:从给定的奖池中抽取出一系列中奖数字,每个数字只能被选取一次。程序实现如下:importjava.util.Arrays;importjava.util.Scanner;publicclass…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

参考文章 https://blog.csdn.net/zzq1992126/article/details/44118429
参考书籍《java核心技术·卷一:基础知识》
代码

package cn.itcast.day04.demo02;
//程序目标:从给定的奖池中抽取出一系列中奖数字,每个数字只能被选取一次。程序实现如下:

import java.util.Arrays;
import java.util.Scanner;

public class LottryDrawing {
    public static void main(String[] args) {
        System.out.println("请输入最大抽奖数字,就是奖池最大多少,也就是从哪个范围随机生成中奖数字");
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();

        System.out.println("请输入抽奖个数,就是就是生成几个抽奖次数," +
                "Math.random() * n 生成的数字就是中奖数字,没有指定的中奖数字,不要胡乱联想");
        Scanner input1 = new Scanner(System.in);
        int k = input.nextInt();

       //接下来生成数组,也就是奖池,通过for循环生成
        int [] numbers = new int[n];
        for (int i = 0; i < n; i++) {
            //中奖数字不为0,不重要
            numbers[i] = i+1;
        }

        //new 一个数组存放中奖数字
        int [] result = new int [k];
        //初始化这个数组,也是就,随机生成中奖数字。
        for (int i = 0; i < result.length ; i++) {
            //r是随机生成numbers数组的一个下标
            int r = (int) (Math.random()*n);
            result[i] = numbers[r]; //这是才是把r下标对应的数赋值给 result数组
            //高能的来了
            numbers[r] = numbers[n-1]; //把numbers数组末尾的数赋值给 numbers[r]
            n--; //就是把numbers末尾的数去掉 因为已经赋给number[r]了,不去掉就重复了。
        }

        //给数组排序并显示结果
        Arrays.sort(result);
        System.out.println("显示抽奖结果");
        for(int i=0;i<result.length;i++){
            System.out.print(result[i]+" ");
        }



    }


}

Jetbrains全家桶1年46,售后保障稳定

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/203730.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月9日 下午11:22
下一篇 2025年8月10日 上午7:01


相关推荐

  • 比较复杂的sql面试题「建议收藏」

    一、分组统计每个班的分数前三名(等同于LeetCode:185. DepartmentTopThreeSalaries)表结构:createtablestudent(idvarchar(20),–编号classvarchar(20),–年级scoreint–分数);insertstudentvalues(‘1′,’一年级’,82);…

    2022年4月13日
    112
  • [Python从零到壹] 十二.机器学习之回归分析万字总结全网首发(线性回归、多项式回归、逻辑回归)

    [Python从零到壹] 十二.机器学习之回归分析万字总结全网首发(线性回归、多项式回归、逻辑回归)前一篇文章讲述了数据分析部分 主要普及网络数据分析的基本概念 讲述数据分析流程和相关技术 同时详细讲解 Python 提供的若干第三方数据分析库 包括 Numpy Pandas Matplotlib Sklearn 等 本文介绍回归模型的原理知识 包括线性回归 多项式回归和逻辑回归 并详细介绍 PythonSklear 机器学习库的 LinearRegres 和 LogisticRegr 算法及回归分析实例 进入基础文章 希望对您有所帮助

    2026年3月26日
    3
  • 【spring】c3p0操作

    【spring】c3p0操作【spring】c3p0操作

    2022年4月25日
    33
  • vfs_fsync[通俗易懂]

    vfs_fsync[通俗易懂]在Linux系统中,对文件系统上文件的读写一般是通过页缓存(pagecache)进行的(DirectIO除外),这样设计的可以延时磁盘IO的操作,从而可以减少磁盘读写的次数,提升IO性能。但是性能和可靠性在一定程度上往往是矛盾的,虽然内核中设计有一个工作队列执行赃页回写同磁盘文件进行同步,但是在一些极端的情况下还是免不了掉电数据丢失。因此内核提供了sync、fsync、fdatasync和msync系统调用用于同步,其中sync会同步整个系统下的所有文件系统以及块设备,而fsync和fdatasync只针

    2022年5月7日
    81
  • java 激活码【最新永久激活】

    (java 激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1PA3AFINM4-eyJsa…

    2022年3月31日
    79
  • 如何完整卸载MySQL[通俗易懂]

    如何完整卸载MySQL[通俗易懂]如果MySQL没有卸载干净,想重装就不行了,本人按照网上的教程来过一遍,但是总是会有残留,于是自己琢磨了一下:1.先停止mysql服务,cmd模式下输入netstopmysql;2.进入控制面板卸载mysql;3.删除mysql文件夹下的my.ini文件及所有文件;4.运行“regedit”文件,打开注册表删除HKEY_LOCAL_M

    2022年6月17日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号