java實(shí)現(xiàn)隨機(jī)抽取獎(jiǎng)品工具類
本文實(shí)例為大家分享了java實(shí)現(xiàn)隨機(jī)抽取獎(jiǎng)品工具類的具體代碼,供大家參考,具體內(nèi)容如下
隨機(jī)抽取獎(jiǎng)品

整體思路:
1.獎(jiǎng)品集合 + 概率比例集合
2.將獎(jiǎng)品按集合中的順序概率計(jì)算成所占比例區(qū)間,放入比例集合。并產(chǎn)生一個(gè)隨機(jī)數(shù)加入其中,進(jìn)行排序。
3.排序后隨機(jī)數(shù)落在那個(gè)區(qū)間就表示那個(gè)區(qū)間的獎(jiǎng)品被抽中。
4.返回的隨機(jī)數(shù)在集合中的索引,該索引就是獎(jiǎng)品集合的中的索引。
5.比例區(qū)間的計(jì)算通過概率相加獲得。
//獎(jiǎng)品的實(shí)體類
public class Gift {
private String id; //獎(jiǎng)品Id
private String name; //獎(jiǎng)品名稱
private double prob; //獲獎(jiǎng)概率
private String type;
}
實(shí)現(xiàn)方法:
public class DrawLotteryUtil {
public static int drawGift(List<Gift> giftList){
if(null != giftList && giftList.size()>0){
List<Double> orgProbList = new ArrayList<Double>(giftList.size());
for(Gift gift:giftList){
//按順序?qū)⒏怕侍砑拥郊现?
orgProbList.add(gift.getProb());
}
return draw(orgProbList);
}
return -1;
}
public static int draw(List<Double> giftProbList){
List<Double> sortRateList = new ArrayList<Double>();
// 計(jì)算概率總和
Double sumRate = 0D;
for(Double prob : giftProbList){
sumRate += prob;
}
if(sumRate != 0){
double rate = 0D; //概率所占比例
for(Double prob : giftProbList){
rate += prob;
// 構(gòu)建一個(gè)比例區(qū)段組成的集合(避免概率和不為1)
sortRateList.add(rate / sumRate);
}
// 隨機(jī)生成一個(gè)隨機(jī)數(shù),并排序
double random = Math.random();
sortRateList.add(random);
Collections.sort(sortRateList);
// 返回該隨機(jī)數(shù)在比例集合中的索引
return sortRateList.indexOf(random);
}
return -1;
}
//測(cè)試
public static void main(String[] args) {
Gift iphone = new Gift();
iphone.setName("10000元");
iphone.setProb(0.9D);
Gift thanks = new Gift();
thanks.setName("28888元");
thanks.setProb(0.04D);
Gift vip = new Gift();
vip.setName("66666元");
vip.setProb(0.03D);
Gift vip1 = new Gift();
vip1.setName("88888元");
vip1.setProb(0.02D);
Gift vip2 = new Gift();
vip2.setName("100000元");
vip2.setProb(0.01D);
List<Gift> list = new ArrayList<Gift>();
list.add(vip);
list.add(thanks);
list.add(iphone);
list.add(vip1);
list.add(vip2);
for(int i=0;i<20;i++){
int index = drawGift(list);
System.out.println("獎(jiǎng)品:"+list.get(index).getName()+"***抽中的概率:"+list.get(index).getProb());
}
}
}
測(cè)試結(jié)果:
獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:66666元***抽中的概率:0.03 獎(jiǎng)品:28888元***抽中的概率:0.04 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:28888元***抽中的概率:0.04 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:88888元***抽中的概率:0.02 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9 獎(jiǎng)品:10000元***抽中的概率:0.9
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在Spring Boot中加載初始化數(shù)據(jù)的實(shí)現(xiàn)
這篇文章主要介紹了在Spring Boot中加載初始化數(shù)據(jù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
詳解spring mvc4使用及json 日期轉(zhuǎn)換解決方案
本篇文章主要介紹了spring mvc4使用及json 日期轉(zhuǎn)換解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
Spring的請(qǐng)求映射handlerMapping以及原理詳解
這篇文章主要介紹了Spring的請(qǐng)求映射handlerMapping以及原理詳解,我們每次發(fā)請(qǐng)求,它到底是怎么找到我們哪個(gè)方法來去處理這個(gè)請(qǐng)求,因?yàn)槲覀冎浪械恼?qǐng)求過來都會(huì)來到DispatcherServlet,springboot底層還是使用的是springMVC,需要的朋友可以參考下2023-08-08
java 中RSA的方式實(shí)現(xiàn)非對(duì)稱加密的實(shí)例
這篇文章主要介紹了java 中RSA的方式實(shí)現(xiàn)非對(duì)稱加密的實(shí)例的相關(guān)資料,這里提供實(shí)例幫助大家理解這部分知識(shí),需要的朋友可以參考下2017-08-08
Java8實(shí)戰(zhàn)之Stream的延遲計(jì)算
JDK中Stream的中間函數(shù)如 filter(Predicate super T>)是惰性求值的,filter并非對(duì)流中所有元素調(diào)用傳遞給它的Predicate,下面這篇文章主要給大家介紹了關(guān)于Java8實(shí)戰(zhàn)之Stream延遲計(jì)算的相關(guān)資料,需要的朋友可以參考下2021-09-09
Spring Data JPA 建立表的聯(lián)合主鍵
這篇文章主要介紹了Spring Data JPA 建立表的聯(lián)合主鍵。本文詳細(xì)的介紹了2種方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04
java實(shí)現(xiàn)Runnable接口適合資源的共享
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)Runnable接口適合資源的共享,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07

