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编写的抽奖程序中奖概率算法