非等概率抽奖抽奖逻辑

版权声明:本文为博主亲身经历,有不懂的地方,欢迎来我的博客留言讨论。 https://blog.csdn.net/wzw19950216/article/details/82215822

前言

  最近依据项目需求,需要做一个抽奖的界面.既然涉及到了抽奖,那么,就应该对于抽奖有一些简单的逻辑判断:首先需要从所有的奖品中选取出正在使用的奖品,然后根据每个奖品不同的中奖权重进行抽奖,这里只做一个简单的处理方式.

逻辑

  首先我们假设只有两个奖品,中奖的概率分别是10和20,那么这时,我会用一个新的数组将这些中奖的概率’存放’起来,—>[1,10,30], 明显[1,10],区间长度是10,(10,30]区间长度是20,然后只需要产生一个在[1,30]中的随机数,判断这个随机数在哪个区间当中就可以:比如此时产生的随机数是9,那么9在[1,10]之间,那么就中第一个奖品,如果产生的随机数是15,15在(10,30]中,那么中第二个奖品.
  当然这是在只有两种奖品的情况下,下面进行推广,假如有十个奖品,该怎么做?   首先:将这些奖品的比率进行排序,降序或者升序都可以,然后再沿用上面的方法就可以.

后记

  纵观整个过程,其实都很简单,第一步:将所有的奖品概率都查询出来,按照降序的顺序进行排序,这一步在数据库查询的时候就可以做到.第二步:将这些概率进行处理,生成一个全新的数组~第三步:生成随机数,第四步:判断随机数在数组的第几个部分,就是第几个奖品.整个过程来说并没有什么复杂的地方.实践一下也是可以的~
更多精彩内容,请点这里,另外欢迎大家给小编留言

猜你喜欢

转载自blog.csdn.net/wzw19950216/article/details/82215822