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

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

时间:2019-11-19 08:09:05

相关推荐

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

后端开发|php教程

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

后端开发-php教程

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

餐饮娱乐网站源码,vscode护眼主题推荐,ubuntu识别网络,tomcat 如何胚子,sqlite3并发数量,前端框架简笔画风景色彩,房间里面有好多小爬虫,c socket php,seo优化哪个正规,网站客服悬浮代码,微信浮动网页,html5 博客模板lzw

$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);

免费影楼源码,vscode工作台字体大小,配置ubuntu更新,tomcat默认管理员,东爬虫书店,php中进制转换,广西seo优化网络推广电话lzw

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

力软信息化快速开发框架 源码,给vscode做插件赚钱,ubuntu 编辑分区,tomcat进程怎么关掉,爬虫过期邮件,php读取js变量,浙江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

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