CodeIgniter-Lottery - php ci 抽奖辅助函数
CodeIgniter-Lottery - php ci 抽奖辅助函数
Github
用法
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 抽奖辅助函数的更多相关文章
- ***CI查询辅助函数:insert_id()、affected_rows()
查询辅助函数 $this->db->insert_id() 这个ID号是执行数据插入时的ID. $this->db->affected_rows() Displays the ...
- CI URL 辅助函数 url helper
URL 辅助函数文件包含一些在处理 URL 中很有用的函数 加载辅助函数 本辅助函数通过如下代码加载: $this->load->helper('url'); 可用函数如下: site_u ...
- ci框架——辅助函数
辅助函数:application/helper下面.命名要求为***_helper.php;这样在调用的时候直接$this->load->helper('***');若想给自定义的辅助函数 ...
- CI框架篇之辅助函数篇--基本(1)
辅助函数 每个辅助函数文件仅仅是一些函数的集合URL Helpers 可以帮助我们创建链接, Form Helpers 可以帮助我们创建表单,Text Helpers 提供一系列的格式化输出方式, C ...
- CI 学习笔记、记录
[ci框架]ci框架目录结构分析 分类: [CodeIgniter深入研究]2013-05-09 00:24 7420人阅读 评论(5) 收藏 举报 [php] view plaincopy mysh ...
- 第一天ci框架开发商城2
ci框架开发商城2 1/28/2016 9:45:52 PM mvc完整案例 mvc完成新闻的增删改查 news控制器news.php class News extends CI_controller ...
- codeigniter文件上传问题
codeigniter自带的文件下载辅助函数非常简单实用,但是在处理大文件的时候,就显得捉襟见肘. 在网上找到了一个对download_helper.php文件的扩展,非常好用,记录下,遇到相同问题的 ...
- 使用 CodeIgniter 框架快速开发 PHP 应用(二)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(二) 二分钟: 建立一个 CodeIgniter 网站用CI建一个网站很容易. 这一章很短,解释了用CI制作网站时发生了些什么,哪些文件 ...
- 使用 CodeIgniter 框架快速开发 PHP 应用(三)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...
随机推荐
- Oracle查询和问题简记
现在做两个版本的系统,一个用的数据库是Access,另一个就是Oracle了.每个数据库支持的的查询SQL语句都有所区别,这里主要针对Access和Oracle做 记录. 首先贴出遇到问题最多的一条语 ...
- redis主从复制配置
master配置 主要是下面配置 # ~~~ WARNING ~~~ If the computer running Redis is directly exposed to the # intern ...
- android ADT 无法查看第三方jar源代码
Source not foundThe JAR of this class file belongs to container 'Android Private Libraries' which do ...
- 用itextsharp打印pdf示例
学习了用itextsharp输出PDF文档,支持用XML定义文档,可定义多个数据源,简单的表达式,用于项目中效果还不错,其中PdfPageEvent类由包大人提供. 示例程序定义了一个简单的xml文件 ...
- Node.js 框架
Node.js的是一个JavaScript平台,它允许你建立大型的Web应用程序. Node.js的框架平台使用JavaScript作为它的脚本语言来构建可伸缩的应用. 当涉及到Web应用程序的开发 ...
- PHP ob_start() 函数介绍
ob_start() 函数介绍: http://www.nowamagic.net/php/php_ObStart.php ob_start()作用: http://zhidao.baidu.com/ ...
- [ASP.NET MVC 小牛之路]02 - C#知识点提要
本人博客已转移至:http://www.exblr.com/liam 本篇博文主要对asp.net mvc开发需要撑握的C#语言知识点进行简单回顾,尤其是C# 3.0才有的一些C#语言特性.对于正在 ...
- Windows Azure Storage (23) 计算Azure VHD实际使用容量
<Windows Azure Platform 系列文章目录> 对于A系列和D系列的虚拟机来说,使用的是普通存储. 普通存储的存储资源,是按照每GB每月计费的.Microsoft Azur ...
- 《Entity Framework 6 Recipes》中文翻译系列 (19) -----第三章 查询之使用位操作和多属性连接(join)
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-16 过滤中使用位操作 问题 你想在查询的过滤条件中使用位操作. 解决方案 假 ...
- maven package 知识(转载)
“打包“这个词听起来比较土,比较正式的说法应该是”构建项目软件包“,具体说就是将项目中的各种文件,比如源代码.编译生成的字节码.配置文件.文档,按照规范的格式生成归档,最常见的当然就是JAR包和WAR ...