1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > 基于PHP代码实现中奖概率算法可用于刮刮卡 大转盘等抽奖算法

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

时间:2019-04-02 05:58:33

相关推荐

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

php教程|php手册

大转盘,刮刮卡,中奖,概率,

php教程-php手册

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

ourphp源码下载,如何注册ubuntu邮箱,tomcat启动如何隐藏启动框,爬虫chrome 插件,php公司用什么模式开发,泰州seo接单lzw

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

thinksns v4收费版源码,ubuntu文件删不了,python爬虫抓取论坛,php视频发布,太原建站seolzw

$proCur) { $randNum = mt_rand(1, $proSum); if ($randNum 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[ o]中, * 最后输出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[ o] = $pr; print_r($res);

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

发布站带后台源码,vscode打开dll文件,ubuntu jpeg库,tomcat版本如何选,sqlite3官网下载,爬虫可以爬取完整的网页资料吗,php静态方法好处,重庆效果好seo推广,模块网站,手机设计网页模板免费下载lzw

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

package Mzone;

import java.util.ArrayList;

import java.util.Random;

public class Mzone {

/**

* CopyRright(c)-04:

* Project:

* Module ID:

* Comments: 概率计算

* JDK version used:

* Author:ch

* Create Date:-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 = 0 && ri = first && ri = second && ri = third && ri = four && 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编写的抽奖程序中奖概率算法

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。