paip 刮刮卡砸金蛋抽奖概率算法跟核心流程

2023-11-07 15:58

本文主要是介绍paip 刮刮卡砸金蛋抽奖概率算法跟核心流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

paip.刮刮卡砸金蛋抽奖概率算法跟核心流程.

 

#---抽奖算法需要满足的需求如下: 1

#---抽奖核心流程 1

#---问题???更好的算法 2

#---实际使用的扩展抽奖算法(带奖品送完判断和每用户最大中奖判断) 2

#-------网上的抽奖算法Php 3

#----java版本的.. 4

参考 5

 

 

#---抽奖算法需要满足的需求如下:

 

1.可以控制中奖的概率

 

2.具有随机性

 

3.最好可以控制奖品的数量

 

4.根据用户ID或者ip、手机号、QQ号等条件限制抽奖次数

 

 

初期就这些需求,然后根据网上的资料,采用了一种阶段式抽取的方法,大家下面看一下整体的程序:

 

关联的数据结构

 [id]      ,[activityId]      ,[awardName]      ,[awardCount]      ,[概率]

 

作者 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax

 

#---抽奖核心流程

//判断每用户每个活动的最大bingo数字...

if (bingoedNum(uid,actid.toString()) >= perUserMaxBigonNum) {

return null;

}

 

   StartAwd()

if (awd == null)

return null;

// 判断奖品是否送完

if (awdOver(awd)) {

return null;

Reutnr awd.

 

 

 

#---问题???更好的算法

网上的算法是没问题的,就是理解起来麻烦的...不是一个真实的阶段式抽取的方法...

例如俄们子有一个奖品,算法的时候儿子要不个probability   概率算呱走ok兰...

有3个奖品,子要不个哪for给挂走ok兰木....

 

public static Awardx getBingoAwd(List<Awardx> li) {

int rdmAwdIndex_may=randomx.random(li.size()-1);

System.out.println("may index::"+rdmAwdIndex_may);

Awardx awd=(Awardx) li.get(rdmAwdIndex_may);

int rdm=randomx.random(100);

core.log("--o42910: rdmAwdIndex_may--rdm--awd.prbblt"+String.valueOf(rdmAwdIndex_may)+"--"+String.valueOf(rdm)+"--"+String.valueOf(awd.prbblt));

if(rdm<awd.prbblt)

{

//bingo

return awd;

}

return null;

}

 

#---实际使用的扩展抽奖算法(带奖品送完判断和每用户最大中奖判断)

protected Awardx startAward(Integer actid, String uid) {

 

if (bingoedNum(uid,actid.toString()) >= perUserMaxBigonNum) {

return null;

}

 

List<ActAward> li = AwdListByActid(actid);

List<Awardx> li_fnl = listUtil.map_generic(li,

new Func_4SingleObj<ActAward, Awardx>() {

 

@Override

public Awardx invoke(ActAward o) {

// 上午08:53:09 2014-4-29

ActAward thisAwd = o;

Awardx awd = new Awardx();

awd.id = thisAwd.getId();

awd.name = thisAwd.getAwardName();

awd.prbblt = thisAwd.getRate();

return awd;

}

});

Awardx awd = com.attilax.award.AwdSvs.getBingoAwd(li_fnl);

if (awd == null)

return null;

if (awdOver(awd)) {

return null;

} else

return awd;

}

 

#-------网上的抽奖算法Php

 /**

     * 根据概率获取中奖号码

     */

    private function get_rand($proArr) {

        $result = '';

        //概率数组的总概率精度

        $proSum = array_sum($proArr);

        //概率数组循环

        foreach ($proArr as $key => $proCur) {

            $randNum = mt_rand(1, $proSum);

            if ($randNum <= $proCur) {

                $result = $key;

                break;

            } else {

                $proSum -= $proCur;

            }

        }

        unset($proArr);

        return $result;

    }

     

}

 

#----java版本的..

/**

 * @category 获取中奖概率

 * 

 */

private static ActAward getAwardRand(List<ActAward> awardList) {

ActAward shootAward = null;

/*return shootAward = awardList.get(0);*/

//测试

if (awardList != null && awardList.size() > 0) {

 

int size = awardList.size();

int seed = 10000;

// 中奖总概率

for (ActAward aa : awardList) {

seed += aa.getRate();

}

// 循环奖项

for (int i = 0; i < size; i++) {

ActAward one = awardList.get(i);

Random rand = new Random();

// 获取1-100之间的概率

int randNum = rand.nextInt(seed);

logger.info("随机概率  >>> " + randNum);

// 中奖了

if (randNum <= i) {

shootAward = one;

break;

} else {

// 继续

seed -= one.getRate();

}

}

}

return shootAward;

}

 

 

参考

转轮抽奖的算法实现-Java-第七城市

php中奖概率算法,可用于刮刮卡,大转盘等抽奖算法 - PHP教程_PHP编程_PHP开发技术文章 - 红黑联盟

PHP中奖概率的抽奖算法程序代码

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow
这里写图片描述

这篇关于paip 刮刮卡砸金蛋抽奖概率算法跟核心流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/364695

相关文章

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级