需要用到 JAVA中的Random()函数

注意:大转盘抽奖各奖项中奖概率之和为 1。奖品列表中的概率为累加概率,需要按照添加进列表的顺序进行累加,添加顺序不做要求。

实际中使用需要考虑奖品数量限制等业务需求,该代码只是个简单的抽奖demo。

奖品数量限制的话,如果需要保证剩余奖品概率比例不变,需要重新构建奖品列表。

package com.wangbo.choujiang;

import java.util.ArrayList;
import java.util.List;
import java.util.Random; /**
* 大转盘抽奖
* @author wangbo
* @date 2019-05-22 14:54:47
*/
public class Test1 { public static void main(String[] args) { List<Award> awardList = new ArrayList<Award>();
Award award1 = new Award();
award1.setAwardName("手机");//10%
award1.setProbability(0.1);
awardList.add(award1); Award award2 = new Award();
award2.setAwardName("水杯");//20%
award2.setProbability(0.2+0.1);//概率加上上一个奖品的概率(累加)
awardList.add(award2); Award award4 = new Award();
award4.setAwardName("鼠标");//10%
award4.setProbability(0.1+0.2+0.1);
awardList.add(award4); Award award5 = new Award();
award5.setAwardName("谢谢惠顾");//60%
award5.setProbability(1d);//最后一个肯定是1
awardList.add(award5); Random random = new Random();
int a = 0,b = 0,c = 0,d = 0;
for (int i = 0; i < 10000; i++) { Double userSelect = random.nextDouble();//0.0-1.0的double随机数(不包括1.0)
String awardName = duageAward(userSelect, awardList);
//信息统计
if ("手机".equals(awardName)) {
a++;
}else if ("水杯".equals(awardName)) {
b++;
}else if ("鼠标".equals(awardName)) {
c++;
}else if ("谢谢惠顾".equals(awardName)){
d++;
}
}
System.out.println("手机 " + a + " 次");
System.out.println("水杯 " + b + " 次");
System.out.println("鼠标 " + c + " 次");
System.out.println("谢谢惠顾 " + d + " 次");
} /**
* 选奖品
* @param userSelect
* @param awardList
* @return
*/
public static String duageAward(Double userSelect, List<Award> awardList){
for (Award award : awardList) {
if(userSelect < award.getProbability()){
return award.getAwardName();
}
}
return null;
} } class Award{
private String awardName;
private Double probability;
public String getAwardName() {
return awardName;
}
public Double getProbability() {
return probability;
}
public void setAwardName(String awardName) {
this.awardName = awardName;
}
public void setProbability(Double probability) {
this.probability = probability;
} }

运行结果:

Java 实现大转盘抽奖的更多相关文章

  1. jquery——九宫格大转盘抽奖

    一.用到的图片 二.代码如下,重点是js部分 <!DOCTYPE html> <html> <head> <meta http-equiv="Con ...

  2. 纯CSS3大转盘抽奖(响应式、可配置)

    源于前段时候微信小程序最初火爆公测时段,把以前用 Canvas 实现的大转盘抽奖移植成微信小程序,无奈当时小程序对 Canvas 支持不够完善,只好降低用 CSS3 实现.虽然比不上 Canvas 绘 ...

  3. PHP实现大转盘抽奖算法实例

    本文主要向大家介绍了PHP语言实现大转盘抽奖算法,通过具体的实例向大家展示,希望对大家学习PHP抽奖有所帮助. 流程:1.拼装奖项数组,2.计算概率,3.返回中奖情况 代码如下:中奖概率 ' v ' ...

  4. PHP+AJAX开发幸运大转盘抽奖

    PHP+AJAX开发幸运大转盘抽奖,通过奖品库存.中奖次数来计算中奖概率 奖品设置 $prizes = array( 0 => array( "id" => 0, // ...

  5. C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断

    C#保留2位小数几种场景总结   场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...

  6. 【Vue.js游戏机实战】- Vue.js实现大转盘抽奖总结

    大家好!先上图看看本次案例的整体效果. 实现思路: Vue component实现大转盘组件,可以嵌套到任意要使用的页面. css3 transform控制大转盘抽奖过程的动画效果. 抽奖组件内使用钩 ...

  7. php 大转盘抽奖

    包在文件中 lottery.zip <!DOCTYPE HTML><html><head><meta charset="utf-8"> ...

  8. php大转盘抽奖

    抽奖大转盘演示:http://www.sucaihuo.com/php/3301.html function getRand($proArr, $proCount) { $result = ''; $ ...

  9. PHP新写的大转盘抽奖源码

    中奖概率 抽奖大转盘演示:http://www.sucaihuo.com/php/3301.html function getRand($proArr, $proCount) { $result = ...

随机推荐

  1. 【ACM-ICPC 2018 徐州赛区网络预赛】D.Easy Math 杜教筛

    代码 #include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 20000000; ...

  2. mfc创建文档视图过程

    一.如何创建文档视图界面: 创建新的文档视图界面,只需要调用CDocTemplate::OpenDocumentFile(strpath)即可.(strpath为要打开的文档路径,如果是NULL,则生 ...

  3. 【leetcode刷题笔记】Pow(x, n)

    Implement pow(x, n). 题解:注意两点: 普通的递归把n降为n-1会超时,要用二分的方法,每次把xn = x[n/2] * x[n/2] * xn-[n/2]*2, [n/2]表示n ...

  4. [转]_int64、long long 的区别

    大学生程序代写 C++的64位整数[原]by 赤兔 http://baike.baidu.com/view/1235293.htm 在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常 ...

  5. bzoj 1113 海报pla

    Description N个矩形,排成一排. 现在希望用尽量少的矩形海报Cover住它们. Input 第一行给出数字N,代表有N个矩形.N在[1,250000] 下面N行,每行给出矩形的长与宽.其值 ...

  6. 如何查看Python 安装位置以及已经安装的库

    如何查看Python 安装位置以及已经安装的库 步骤一: 1. Start 一个command prompt 2. 找到电脑中已经安装的Python 位置: where python 1 打开路径, ...

  7. POJ3468(树状数组区间维护)

    A Simple Problem with Integers Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 89818   ...

  8. mount总结

    挂载分区 mount基本语法 mount [参数] /dev/sdb1(需要挂载的分区) /sdb1(挂载目录) 参数是可选的,也可以不带参数,参数的使用方法(-o ro,sync,atime). 参 ...

  9. TS学习之Symbol

    symbol成为了一种新的原生类型,就像number和string一样(意思是可以像string一样,作为对象的属性等) Symbols是不可改变且唯一的 //symbol通过Symbol函数构造,但 ...

  10. nginx gzip

    # 开启gzip gzip on;   # 启用gzip压缩的最小文件,小于设置值的文件将不会压缩 gzip_min_length 1k;   # gzip 压缩级别,1-10,数字越大压缩的越好,也 ...