基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法


Posted in PHP onDecember 20, 2015

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

<?php
/*
 * 经典的概率算法,
 * $proArr是一个预先设置的数组,
 * 假设数组为:array(100,200,300,400),
 * 开始是从1,1000 这个概率范围内筛选第一个数是否在他的出现概率范围之内, 
 * 如果不在,则将概率空间,也就是k的值减去刚刚的那个数字的概率空间,
 * 在本例当中就是减去100,也就是说第二个数是在1,900这个范围内筛选的。
 * 这样 筛选到最终,总会有一个数满足要求。
 * 就相当于去一个箱子里摸东西,
 * 第一个不是,第二个不是,第三个还不是,那最后一个一定是。
 * 这个算法简单,而且效率非常 高,
 * 关键是这个算法已在我们以前的项目中有应用,尤其是大数据量的项目中效率非常棒。
 */
function get_rand($proArr) { 
 $result = ''; 
 //概率数组的总概率精度 
 $proSum = array_sum($proArr); 
 //概率数组循环 
 foreach ($proArr as $key => $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<count($prize_arr);$i++){ 
 $pr[] = $prize_arr[$i]['prize']; 
} 
$res['no'] = $pr; 
print_r($res);

下面再给大家分享一段实例代码基于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: <JDK1.4>
 * 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<list.size();i++){
   Integer temp = (Integer)list.get(i);
   t = gys(t,temp.intValue());
  }
  return t; 
 }
 /**
  * 产生随机数
 */
 public static int getRandom(int y){
  int result = r.nextInt(y);
  return result;
 }
}
PHP 相关文章推荐
一个从别的网站抓取信息的例子(域名查询)
Oct 09 PHP
用PHP中的 == 运算符进行字符串比较
Nov 26 PHP
php中使用Akismet防止垃圾评论的代码
Jun 10 PHP
修改PHP的memory_limit限制的方法分享
Feb 21 PHP
深入PHP magic quotes的详解
Jun 17 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十六)
Jun 30 PHP
ThinkPHP字符串函数及常用函数汇总
Jul 18 PHP
thinkPHP学习笔记之安装配置篇
Mar 05 PHP
PHP新特性详解之命名空间、性状与生成器
Jul 18 PHP
php模式设计之观察者模式应用实例分析
Sep 25 PHP
在TP5数据库中四个字段实现无限分类的示例
Oct 18 PHP
php设计模式之策略模式实例分析【星际争霸游戏案例】
Mar 26 PHP
WordPress中给文章添加自定义字段及后台编辑功能区域
Dec 19 #PHP
利用Fix Rss Feeds插件修复WordPress的Feed显示错误
Dec 19 #PHP
WordPress中Gravatar头像缓存到本地及相关优化的技巧
Dec 19 #PHP
CentOS下与Apache连接的PHP多版本共存方案实现详解
Dec 19 #PHP
PHP程序中使用adodb连接不同数据库的代码实例
Dec 19 #PHP
php实现面包屑导航例子分享
Dec 19 #PHP
php实现倒计时效果
Dec 19 #PHP
You might like
php基础知识:类与对象(4) 范围解析操作符(::)
2006/12/13 PHP
简单介绍win7下搭建apache+php+mysql开发环境
2015/08/06 PHP
Zend Framework动作助手(Zend_Controller_Action_Helper)用法详解
2016/03/05 PHP
php图片添加文字水印实现代码
2016/03/15 PHP
PHP序列化操作方法分析
2016/09/28 PHP
php爬取天猫和淘宝商品数据
2018/02/23 PHP
html读出文本文件内容
2007/01/22 Javascript
JQery jstree 大数据量问题解决方法
2010/03/09 Javascript
JQuery中的$.getJSON 使用说明
2011/03/10 Javascript
hover的用法及live的用法介绍(鼠标悬停效果)
2013/03/29 Javascript
jq选项卡鼠标延迟的插件实例
2013/05/13 Javascript
推荐 21 款优秀的高性能 Node.js 开发框架
2014/08/18 Javascript
Nodejs学习笔记之Global Objects全局对象
2015/01/13 NodeJs
jQuery实现的表头固定效果实例【附完整demo源码下载】
2016/08/01 Javascript
jquery实现图片跟随鼠标的实例
2017/10/17 jQuery
10个在JavaScript开发中常遇到的BUG
2017/12/18 Javascript
详解vue 单页应用(spa)前端路由实现原理
2018/04/04 Javascript
如何解决webpack-dev-server代理常切换问题
2019/01/09 Javascript
微信小程序实现上传word、txt、Excel、PPT等文件功能
2019/05/23 Javascript
vue实现输入框的模糊查询的示例代码(节流函数的应用场景)
2019/09/01 Javascript
vue中实现点击按钮滚动到页面对应位置的方法(使用c3平滑属性实现)
2019/12/29 Javascript
Python基础教程之正则表达式基本语法以及re模块
2016/03/25 Python
Python中的字符串操作和编码Unicode详解
2017/01/18 Python
numpy中以文本的方式存储以及读取数据方法
2018/06/04 Python
python+PyQT实现系统桌面时钟
2020/06/16 Python
Python3 使用pillow库生成随机验证码
2019/08/26 Python
Pycharm 2020年最新激活码(亲测有效)
2020/09/18 Python
Python如何在windows环境安装pip及rarfile
2020/06/15 Python
HTML5 WebGL 实现民航客机飞行监控系统
2019/07/25 HTML / CSS
使用HTML5里的classList操作CSS类
2016/06/28 HTML / CSS
浅谈Html5移动端ios/Android兼容性总结
2018/06/01 HTML / CSS
Crucial英睿达法国官网:内存条及SSD固态硬盘升级
2018/07/13 全球购物
Tahari ASL官方网站:高级设计师女装
2021/03/15 全球购物
副科级后备干部考察材料
2014/05/15 职场文书
vue实现可拖拽的dialog弹框
2021/05/13 Vue.js
Python实现仓库管理系统
2022/05/30 Python