热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

初学者必备_java小项目之:抽奖系统!java初学者必备(内附源码)

篇首语:本文由编程笔记#小编为大家整理,主要介绍了java小项目之:抽奖系统!java初学者必备(内附源码)相关的知识,希望对你有一定的参考价值。【

篇首语:本文由编程笔记#小编为大家整理,主要介绍了java小项目之:抽奖系统!java初学者必备(内附源码)相关的知识,希望对你有一定的参考价值。


Java】Java摇奖源码,Java抽奖源码,Java随机抽奖源码

任务描述

本次任务要求为某商场开发一套幸运抽奖系统,客户必须首先注册成为该商场会员,会员登录成功后,就可以参加抽奖活动了。
注册

用户选择“注册”菜单,进入注册界面。输入用户名和密码后,系统提示注册成功,并给出会员卡号。
登录

注册成功后,用户选择“登录”菜单,进入登录界面。输入注册时的用户名和密码。登录成功,系统提示欢迎信息。如果用户和密码输入错误,提示用户继续输入,最多有3次机会。
抽奖

登录成功后,用户选择“抽奖”菜单,进入幸运抽奖界面。输入会员卡号,系统生成5个4位随机数作为幸运数字。如果会员卡号是其中之一,则成为本日幸运会员。
源代码

import java.math.BigDecimal;import java.util.ArrayList;import java.util.List;

 import com.thinkive.base.jdbc.DataRow;

 public class TurnTable {

 

static Object[][] prizeArr = new  Object[][]{  

        //里面的指针转动  

        {1,"一等奖",0.0001},  

        {2,"不要灰心",39.9994},

        {3,"祝您好运",20.0},  

        {4,"二等奖",0.0002},  

        {5,"再接再厉",20.0},  

        {6,"运气先攒着",10.0},  

        {7,"三等奖",0.0003},  

        {8,"谢谢参与",10.0}

};

Object result[] = award(prizeArr);//抽奖后返回奖品等级及奖品描述

 

//抽奖后返回奖品等级及奖品描述  

public static Object[] award(Object[][] prizeArr){  

   //概率数组  

float obj[] = new float[prizeArr.length];  

   for(int i=0;i

       obj[i] = Float.parseFloat(prizeArr[i][2].toString());  

   }  

   Integer prizeId = getRand(obj); //根据概率获取奖项号码  

   String msg = (String) prizeArr[prizeId][1];//奖品信息

   Integer prizeIds = prizeId +1;

   System.out.println("奖品号: "+prizeIds +" 获奖等级:"+msg);  

     

   return new Object[]{prizeId,msg};  

}

 

 

//根据概率获取奖项  

public static Integer getRand(float obj[]){  

Integer result = null;  

        try {  

            float sum = 0.0f;//概率数组的总概率精度   

            float min = 0.0f;//

            for(int i=0;i

             BigDecimal beforSum = new BigDecimal(Float.toString(sum));

             BigDecimal objValue = new BigDecimal(Float.toString(obj[i]));

             sum = beforSum.add(objValue).floatValue();

            }  

            for(int i=0;i

             BigDecimal db = new BigDecimal(Math.random() * (sum - min) + min);

             BigDecimal b = new BigDecimal(Float.toString(obj[i]));

                if(compareMethod(db,b) == -1){//中奖

                    result = i;  

                    break;  

                }else{  

                    sum -=obj[i];  

                }  

            }  

        } catch (Exception e) {  

            e.printStackTrace();  

        }

        /**

         * 奖品控制代码,这里可以控制我们的奖品的等级

         * **/

   return result;  

}

 

 

 

public static void main(String[] args) {

DataRow data = new DataRow();//此处DataRow为封装了的 HashMap

List resultList = new ArrayList();

for (int i = 0; i <10000; i++) {

int k = 1;

Object result[] = award(prizeArr);//抽奖后返回角度和奖品等级

String prize = "";

String comment = "";

for (Object object : result) {

if(k==1){

prize = object.toString();

}else if(k==2){

comment = object.toString();

}

k++;

}

if(k==3){

data.set("prize", Integer.valueOf(prize)+1);

data.set("comment", comment);

resultList.add(data);

}

}

}

 

public static int compareMethod(BigDecimal a,BigDecimal b){

return a.compareTo(b);

}

}

喜欢这样文章的可以关注我,我会持续更新,你们的关注是我更新的动力!需要更多java学习资料的也可以私信我!

祝关注我的人都:身体健康,财源广进,福如东海,寿比南山,早生贵子,从不掉发!


推荐阅读
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
author-avatar
手机用户2502876217
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有