大转盘中奖概率算法在我们的日常生活中,经常遇到,那么基于php代码是如何实现中奖概率算法的,下面通过一段代码实例给大家介绍php中奖概率算法,代码简单易懂,并且附有注释,具体代码如下所示:

$proCur) {

$randNum = mt_rand(1, $proSum);

if ($randNum <= $proCur) {

$result = $key;

break;

} else {

$proSum -= $proCur;

}

}

unset ($proArr);

return $result;

}

/*

* 奖项数组

* 是一个二维数组,记录了所有本次抽奖的奖项信息,

* 其中id表示中奖等级,prize表示奖品,v表示中奖概率。

* 注意其中的v必须为整数,你可以将对应的 奖项的v设置成0,即意味着该奖项抽中的几率是0,

* 数组中v的总和(基数),基数越大越能体现概率的准确性。

* 本例中v的总和为100,那么平板电脑对应的 中奖概率就是1%,

* 如果v的总和是10000,那中奖概率就是万分之一了。

*

*/

$prize_arr = array(

'0' => array('id'=>1,'prize'=>'平板电脑','v'=>1),

'1' => array('id'=>2,'prize'=>'数码相机','v'=>5),

'2' => array('id'=>3,'prize'=>'音箱设备','v'=>10),

'3' => array('id'=>4,'prize'=>'4G优盘','v'=>12),

'4' => array('id'=>5,'prize'=>'10Q币','v'=>22),

'5' => array('id'=>6,'prize'=>'下次没准就能中哦','v'=>50),

);

/*

* 每次前端页面的请求,PHP循环奖项设置数组,

* 通过概率计算函数get_rand获取抽中的奖项id。

* 将中奖奖品保存在数组$res['yes']中,

* 而剩下的未中奖的信息保存在$res['no']中,

* 最后输出json个数数据给前端页面。

*/

foreach ($prize_arr as $key => $val) {

$arr[$val['id']] = $val['v'];

}

$rid = get_rand($arr); //根据概率获取奖项id

$res['yes'] = $prize_arr[$rid-1]['prize']; //中奖项

unset($prize_arr[$rid-1]); //将中奖项从数组中剔除,剩下未中奖项

shuffle($prize_arr); //打乱数组顺序

for($i=0;$i

下面再给大家分享一段实例代码基于Java实现中奖概率计算

做移动的项目,有个需求,做个摇奖的活动!其中中奖的计算比较恶心,用户要改动各个奖项的中奖概率,而且每天的奖项有个数限制。一二三四五六等奖,概率不通,怎么算一个用户参与了中没中将呢?苦思了一下,可以用Random类的 nextInt(int x)方法产生一个范围内的随机数,产生到那个区间就是几等奖了,中奖区间的产生是动态的。贴出源代码,仅供参考!

package Mzone;

import java.util.ArrayList;

import java.util.Random;

public class Mzone {

/**

* CopyRright(c)2009-04:

* Project:

* Module ID:

* Comments: 概率计算

* JDK version used: * Author:ch

* Create Date:2009-04-20

* Modified By:

* Modified Date:

* Why & What is modified

* Version: 1.0

*/

static Random r = new Random();

public static void main(String[] args) {

//各个奖项的中奖概率的分母

Integer _5m = new Integer(5);

Integer _500m = new Integer(30);

Integer _ipod = new Integer(500);

Integer _phone = new Integer(1000);

Integer _notebook = new Integer(1500);

Integer _jay = new Integer(50);

ArrayList list = new ArrayList();

if(_5m.intValue()!=0)

list.add(_5m);

if(_500m.intValue()!=0)

list.add(_500m);

if(_ipod.intValue()!=0)

list.add(_ipod);

if(_phone.intValue()!=0)

list.add(_phone);

if(_notebook.intValue()!=0)

list.add(_notebook);

if(_jay.intValue()!=0)

list.add(_jay);

//计算最小公倍数

int common = getN(list);

System.out.println("最小公倍数:"+common);

int a = 0;int b = 0;int c = 0;int d = 0;int e = 0;int f = 0;int g = 0;

int first = 0;int second = 0;int third = 0;int four = 0;int fifth = 0;int sixth = 0;

if(_5m.intValue()!=0){

first = common/_5m.intValue();

}

if(_500m.intValue()!=0){

second = first + (common/_500m.intValue());

}else second = first;

if(_ipod.intValue()!=0){

third = second + (common/_ipod.intValue());

}else third = second;

if(_phone.intValue()!=0){

four = third + (common/_phone.intValue());

}else four = third;

if(_notebook.intValue()!=0){

fifth = four + (common/_notebook.intValue());

}else fifth = four;

if(_jay.intValue()!=0){

sixth = fifth + (common/_jay.intValue());

}else sixth = fifth;

int times = 30000;//循环次数

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

int ri = getRandom(common);//产生随机数

if(ri >= 0 && ri < first){

a++;

}else if(ri >= first && ri < second){

b++;

}else if(ri >= second && ri < third){

c++;

}else if(ri >= third && ri < four){

d++;

}else if(ri >= four && ri < fifth){

e++;

}else if(ri >= fifth && ri < sixth){

f++;

}else{

g++;

}

}

System.out.println("5m值:" + a + " 500m值:" + b + " ipodMP3:" + c + " 手机:" + d + " 笔记本电脑:" + e + " 演唱会门票:" + f + " 谢谢参与:" + g);

}

/**

* 求最大公约数

*/

public static int gcd(int m, int n){

while (true){

if ((m = m % n) == 0)

return n;

if ((n = n % m) == 0)

return m;

}

}

/**

* 求最小公倍数

*/

public static int gys(int z, int y){

int t = 0;

int c = 0;

c = gcd(z,y);

t = z * y / c;

return t;

}

/**

* 求几个数的最小公倍数

*/

public static int getN(ArrayList list){

int t = 1;

for(int i = 0;i

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

php刮刮卡代码,基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法_php实例...相关推荐

  1. php中奖概率算法,可用于刮刮卡,大转盘等抽奖算法

    php中奖概率算法,可用于刮刮卡,大转盘等抽奖算法.用法很简单,代码里有详细注释说明,一看就懂 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...

  2. php中奖概率算法,刮刮卡/大转盘抽奖算法

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 php中奖概率算法,可用于刮刮卡,大转盘等抽奖算法 前言 一.概率算法 二.奖项数组 三.引用输出 总结 前言 以下是我整理的在项目中 ...

  3. qq开放平台之站内应用-php抽奖大转盘,jQuery实现大转盘抽奖活动仿QQ音乐代码分享...

    jQuery实现大转盘抽奖活动仿QQ音乐抽奖特效源码是一款基于jQuery,点击大转盘开始抽奖可抽到绿钻的仿qq音乐抽奖转盘的代码. 运行效果图:--------------------------- ...

  4. Canvas实现微信大转盘抽奖代码

    Canvas实现微信大转盘抽奖代码,canvas结合jquery实现的一款大转盘抽奖代码,奖品图片均由canvas绘制,可自定义奖项. jquery抽奖微信大转盘jquery抽奖转盘微信抽奖源代码微信 ...

  5. php充值代码,基于php的加油卡充值接口调用代码实例

    搜索热词 下面是编程之家 jb51.cc 通过网络收集整理的代码片段. 编程之家小编现在分享给大家,也给大家做个参考. 代码描述:基于PHP的加油卡充值接口调用代码实例 关联数据:加油卡充值 接口地址 ...

  6. 加油卡 格式判断 java_[代码全屏查看]-基于JAVA的加油卡充值接口调用代码实例...

    [1].[代码] [Java]代码 import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.IOE ...

  7. PyTorch单机多卡分布式训练教程及代码示例

    导师不是很懂PyTorch的分布式训练流程,我就做了个PyTorch单机多卡的分布式训练介绍,但是他觉得我做的没这篇好PyTorch分布式训练简明教程 - 知乎.这篇讲的确实很好,不过我感觉我做的也还 ...

  8. 【camera】自动泊车-基于深度学习的视觉车位检测项目(课程设计--训练代码、测试代码、部署demo)(2)

    **基于深度学习的点定位回归和角度预测的车位检测 基于深度学习的点定位回归和角度预测 基于深度学习的角点检测和角度回归 ** 项目下载地址:训练代码.测试代码.部署demo 数据集百度网盘下载:数据集 ...

  9. 【深度学习】梯度和方向导数概念解析(代码基于Pytorch实现)

    [深度学习]梯度和方向导数概念解析(代码基于Pytorch实现) 文章目录 1 方向导数 2 梯度 3 自动求导实现 4 梯度下降4.1 概述4.2 小批量梯度下降 5 总结 1 方向导数 方向导数的 ...

  10. 【Android 性能优化】应用启动优化 ( 方法追踪代码模板 | 示例项目 | SD 卡访问权限 | 示例代码 | 获取 Trace 文件 | Android Studio 查看文件)

    文章目录 一. 方法追踪代码模板 二. 追踪 Launch 页面的 onCreate 方法执行情况 1. 示例项目 2. SD 卡访问权限问题 ( 动态权限申请 ) 3. MainActivity o ...

最新文章

  1. 44.作用域,局部和全局变量
  2. P3834 【模板】可持久化线段树 2(整体二分做法)
  3. c++ 一个函数包括多个返回值判断_Python函数的概念和使用
  4. 高级GIT教程——Cherry-Pick vs Rebase vs Merge
  5. java 反转jia链表_Java实现单链表反转
  6. 冠军奖 3 万元!CSDN×易观算法大赛火热进行中
  7. mysql数据库不存在_mysql 数据库不存在
  8. SPFA+Dinic HDOJ 3416 Marriage Match IV
  9. python的menu_Python Tkinter Menu使用教程 | 學步園
  10. 自定义控件2.第一个自定义view
  11. EFCore 调试远程SqlServer数据库提示信号灯超时时间已到
  12. html5 预览dwg,哪个企业网盘可以实现dwg在线预览?
  13. 纬衡、金蝶、腾讯、迅雷获深圳软件明星企业称号
  14. 2021暑假Leetcode刷题——Two Pointers(3)
  15. html5怎么写副标题,毕业论文副标题怎么写
  16. 从现在开始学 Kafka:SpringBoot 集成 Kafka,生产者与消费者示例
  17. iOS 内存五大区讲解
  18. 叶子结点和分支节点_什么是叶子节点,度?根节点?
  19. 《财富》评论:盛大新游戏——陈天桥欲打造中国迪斯尼
  20. Fail to contact Jack Server: Problem reading xxxxxx

热门文章

  1. FreeRTOS移植Error: L6218E: Undefined symbol xTaskGetCurrentTaskHandle (referred from stream_buffer.o).
  2. 磁盘显示无法访问数据错误循环冗余检查的资料恢复法子
  3. (附源码)springboot教材订购系统 毕业设计 081419
  4. 高并发系统设计——API网关技术选型
  5. 图Android 片缓存文件名,手机图片去了哪?教你理清照片存放路径
  6. 开启和关闭android移动网络
  7. 全国计算机演示文稿,全国计算机统考押题——演示文稿
  8. java 导出数据设置进度条_java控制台输出百分比进度条示例
  9. vsual studio 如何关闭禁止mscorsvw.exe (转)
  10. 【PyTorch深度学习项目实战100例】—— 基于UNet实现血管瘤超声图像分割 | 第30例