CodeIgniter-Lottery - php ci 抽奖辅助函数

Github

https://github.com/xjnotxj/CodeIgniter-Lottery

用法

1、 移入文件

lottery_helper.php放在你的工程根目录/application/helpers/

2、导入辅助函数

 $this->load->helper('lottery');

3、调用

//抽奖,返回奖品id
$price_id = lottery($arr); echo $price_id;

关于$arr参数的规范有下面两种方式:

方法一:直接传 array 参数
$arr = array(
array(
"id" => 1,
"rate" => 0.1,
),
array(
"id" => 2,
"rate" => 0.2345,
),
array(
"id" => 3,
"rate" => 0,
)
);

注:

(1) id :奖品编号, rate:奖品中奖概率

(2) id 从 1 开始递增

(3) rate 为 [0,1]

方法二:利用 $query->result_array() 查询数据库后返回的结果$result
$sql = "SELECT `id`,rate  FROM `price_table`";
$query = $this->db->query($sql);
$result = $query->result_array();
if (is_array($result) && count($result, COUNT_NORMAL) > 0) {
return $result;
} else {
return false;
}

算法原理

以上文方法一:直接传 array 参数传的参数举例:

1、定义奖品,记得加上未中奖的情况

type id rate
奖品1 1 0.1
奖品2 2 0.234
奖品3 3 0
未中奖 4 0.6655

2、按照 rate (中奖概率)递增排序

type id rate
奖品3 3 0
奖品1 1 0.1
奖品2 2 0.234
未中奖 4 0.6655

3、取出除 0 以外的最小 rate:min_rate = 0.1,并计算每个奖品的权重值( weight )

权重值计算公式:weight = rate / min_rate

type id rate weight
奖品3 3 0 0
奖品1 1 0.1 1
奖品2 2 0.234 2.345
未中奖 4 0.6655 6.655

4、划分每个奖品的落点范围( range_min , rang_max ],左开右闭

落点范围:

range_min = 上个奖品的 range_max

range_max = range_min + weight

type id rate weight range_min rang_max
奖品3 3 0 0 0 0
奖品1 1 0.1 1 0 1
奖品2 2 0.234 2.345 1 3.345
未中奖 4 0.6655 6.655 3.345 10

5、找出落点范围小数点精确位数最多的奖品,并取出精确位数( max_float_length )

type id rate weight range_min rang_max
奖品2 2 0.234 2.345 1 3.345
未中奖 4 0.6655 6.655 3.345 10

max_float_length = 3.345,即精确位数为小数点后 3

6、生成随机小数的落点

随机小数范围 = rand(1 , max(range_max) * pow(10, max_float_length)) / pow(10, max_float_length)

7、判断随机小数落在哪个奖品的范围

若随机小数 = 2.175 ,即落在奖品2

CodeIgniter-Lottery - php ci 抽奖辅助函数的更多相关文章

  1. ***CI查询辅助函数:insert_id()、affected_rows()

    查询辅助函数 $this->db->insert_id() 这个ID号是执行数据插入时的ID. $this->db->affected_rows() Displays the ...

  2. CI URL 辅助函数 url helper

    URL 辅助函数文件包含一些在处理 URL 中很有用的函数 加载辅助函数 本辅助函数通过如下代码加载: $this->load->helper('url'); 可用函数如下: site_u ...

  3. ci框架——辅助函数

    辅助函数:application/helper下面.命名要求为***_helper.php;这样在调用的时候直接$this->load->helper('***');若想给自定义的辅助函数 ...

  4. CI框架篇之辅助函数篇--基本(1)

    辅助函数 每个辅助函数文件仅仅是一些函数的集合URL Helpers 可以帮助我们创建链接, Form Helpers 可以帮助我们创建表单,Text Helpers 提供一系列的格式化输出方式, C ...

  5. CI 学习笔记、记录

    [ci框架]ci框架目录结构分析 分类: [CodeIgniter深入研究]2013-05-09 00:24 7420人阅读 评论(5) 收藏 举报 [php] view plaincopy mysh ...

  6. 第一天ci框架开发商城2

    ci框架开发商城2 1/28/2016 9:45:52 PM mvc完整案例 mvc完成新闻的增删改查 news控制器news.php class News extends CI_controller ...

  7. codeigniter文件上传问题

    codeigniter自带的文件下载辅助函数非常简单实用,但是在处理大文件的时候,就显得捉襟见肘. 在网上找到了一个对download_helper.php文件的扩展,非常好用,记录下,遇到相同问题的 ...

  8. 使用 CodeIgniter 框架快速开发 PHP 应用(二)

    原文:使用 CodeIgniter 框架快速开发 PHP 应用(二) 二分钟: 建立一个 CodeIgniter 网站用CI建一个网站很容易. 这一章很短,解释了用CI制作网站时发生了些什么,哪些文件 ...

  9. 使用 CodeIgniter 框架快速开发 PHP 应用(三)

    原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...

随机推荐

  1. 【转】你所不知道的Android Studio调试技巧

    这篇写Android studio debug技巧个人觉得写得不错,转自:http://www.jianshu.com/p/011eb88f4e0d# Android Studio目前已经成为开发An ...

  2. Spring4 实例

    结构目录如下: 其中: dao层和entity层都属于hibernate的的管辖.entity层里面装的是每张表对应的持久化类.dao层里面装的是"底层操作数据库的行为",仅仅只是 ...

  3. web预设模块化

  4. <web Font的使用>

    使用font-face将字体引入web中 先将字体文件复制到项目的font文件夹中,CSS样式如下: @font-face { font-family: 'iconfont'; /*字体名称*/ sr ...

  5. Ubuntu 14.04--php的安装和配置

      更新源列表 打开"终端窗口",输入"sudo apt-get update"-->回车-->"输入root用户的密码"--& ...

  6. 判断是否为mac电脑 、还是windows操作系统

    /** * 是否为mac系统(包含iphone手机) * */ var isMac = function() { return /macintosh|mac os x/i.test(navigator ...

  7. javascript中的内置对象总结

    内置对象 标准内置对象 Object Object.create Object.prototype.toString Object.prototype.hasOwnProperty Boolean S ...

  8. ubuntu下 编译安装swftools

    1.下载:http://www.swftools.org/download.html2.安装: tar -zvxf swftools-0.x.x.tar cd swftools-0.x.x ./con ...

  9. window下搭建c开发环境(GNU环境的安装)

    一.在windows平台上安装GNU环境 windows操作系统不自带GNU环境,如果需要开发跨平台的C语言程序,那么需要给windows安装GNU环境 windows下的两款GNU环境:MinGW和 ...

  10. PostgreSQL的.NET驱动程序Npgsql

    Npgsql是PostgreSQL的一个.NET数据提供程序,它可以自由获取.它可以通过下列选项获得独立的下载,也可以安装PostgreSQL数据库程序时选择安装. 最新的_npgsql2 Npgsq ...