Java 实现大转盘抽奖
需要用到 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 实现大转盘抽奖的更多相关文章
- jquery——九宫格大转盘抽奖
一.用到的图片 二.代码如下,重点是js部分 <!DOCTYPE html> <html> <head> <meta http-equiv="Con ...
- 纯CSS3大转盘抽奖(响应式、可配置)
源于前段时候微信小程序最初火爆公测时段,把以前用 Canvas 实现的大转盘抽奖移植成微信小程序,无奈当时小程序对 Canvas 支持不够完善,只好降低用 CSS3 实现.虽然比不上 Canvas 绘 ...
- PHP实现大转盘抽奖算法实例
本文主要向大家介绍了PHP语言实现大转盘抽奖算法,通过具体的实例向大家展示,希望对大家学习PHP抽奖有所帮助. 流程:1.拼装奖项数组,2.计算概率,3.返回中奖情况 代码如下:中奖概率 ' v ' ...
- PHP+AJAX开发幸运大转盘抽奖
PHP+AJAX开发幸运大转盘抽奖,通过奖品库存.中奖次数来计算中奖概率 奖品设置 $prizes = array( 0 => array( "id" => 0, // ...
- C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断
C#保留2位小数几种场景总结 场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...
- 【Vue.js游戏机实战】- Vue.js实现大转盘抽奖总结
大家好!先上图看看本次案例的整体效果. 实现思路: Vue component实现大转盘组件,可以嵌套到任意要使用的页面. css3 transform控制大转盘抽奖过程的动画效果. 抽奖组件内使用钩 ...
- php 大转盘抽奖
包在文件中 lottery.zip <!DOCTYPE HTML><html><head><meta charset="utf-8"> ...
- php大转盘抽奖
抽奖大转盘演示:http://www.sucaihuo.com/php/3301.html function getRand($proArr, $proCount) { $result = ''; $ ...
- PHP新写的大转盘抽奖源码
中奖概率 抽奖大转盘演示:http://www.sucaihuo.com/php/3301.html function getRand($proArr, $proCount) { $result = ...
随机推荐
- JavaUtil_09_email_使用 commons-email 发送邮件
二.参考资料 1.[commons]邮件发送工具——commons-email
- list dict set comprehension 列表推导式 (字典推导式,集合推导式)
从一个list生成新的list [ word.upper() for word in 'hellO worlD!' ] 简单的语法,如果不用list comprehension, 则要用更长的代码. ...
- FFMPEG实现的转码程序
本例子是由FFEMPG的doc/example例子transcode.c修改而来,可以根据需求任意转换音视频的编码. 原来的例子的作用更类似于remux,并没有实现转码的功能,只是实现了格式转换,比如 ...
- BZOJ5324 JXOI2018 守卫
传送门 这是我见过的为数不多的良心九怜题之一 题目大意 给定一段$n$个点构成的折线,第$i$个折点的坐标是$(i,h_i)$,你可以在$i$点放置一个视野,定义$i$能看到$j$当且仅当$i$处有视 ...
- Java Main Differences between HashMap HashTable and ConcurrentHashMap
转自这篇帖子:http://www.importnew.com/7010.html HashMap和Hashtable的比较是Java面试中的常见问题,用来考验程序员是否能够正确使用集合类以及是否可以 ...
- uoj problem 14 DZY Loves Graph
题目: DZY开始有 \(n\) 个点,现在他对这 \(n\) 个点进行了 \(m\) 次操作,对于第 \(i\) 个操作(从 \(1\) 开始编号)有可能的三种情况: Add a b: 表示在 \( ...
- 2.2synchronized同步语句块
使用synchronized虽然能够避免不同步的现象出现,但是也会出现弊端,比如代码执行时间过长,那么其他线程就必须等待该线程执行完毕释放锁之后才能拿到锁. 面对这种问题可以使用同步代码块来解决. 2 ...
- from selenium.webdriver.support.ui import Select
from selenium.webdriver.support.ui import Select Select(d.find_element_by_id(u'key_开户行')).first_sele ...
- Poj 2299 Ultra-QuickSort(归并排序求逆序数)
一.题意 给定数组,求交换几次相邻元素能是数组有序. 二.题解 刚开始以为是水题,心想这不就是简单的冒泡排序么.但是毫无疑问地超时了,因为题目中n<500000,而冒泡排序总的平均时间复杂度为, ...
- POJ(2186)强连通分量分解
#include<cstdio> #include<vector> #include<cstring> using namespace std; ; vector& ...