后端开发|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