android随机抽奖代码_幸运大转盘抽奖 抽奖算法 程序实现逻辑

本文主要是介绍android随机抽奖代码_幸运大转盘抽奖 抽奖算法 程序实现逻辑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

近期碰到的一个需求,实现一个类似大转盘抽奖的功能,需自定义奖项,各奖项中奖概率,当日抽奖最大次数,抽奖成本等。分享一个简单的java代码的实现的思路,有不足之处感谢各位指正。

3222d8e23d1b9889a6913d8d1fb14.png

初步方法

首先要定义几个奖品,例如:

iphone 中奖机率 10%

100元购物卷 中奖机率 30%

10元购物卷 中奖机率 50%

总的中奖机率是 10%+30%+50%=90%

剩余10%是谢谢惠顾,不中奖的

设计思路

这个是把所有商品按照概率分配到数组里面

A[0] = iphone

A[1] = iphone

A[2] = iphone

...

A[10] = iphone

A[11] = 100元购物卷

A[12] = 100元购物卷

...

然后随机一个0到99的数字,例如现在随机的数字是2

那么A[2]就是中奖的商品A[2] = iphone

//定义中奖率分母 百分之

int probabilityCount = 100;

String[] prizesId = new String[probabilityCount];

//获取商品列表

List prizeInfoList = prizeInfoService.getPrizeInfo();

int num = 0;

//循环所有商品

for (AdPrizeInfo prize : prizeInfoList) {

Integer probability = prize.getOdds();

//循环商品概率

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

prizesId[num] = prize.getId();

num ++;

}

}

//随机一个数字

int index = (int) (Math.random() * probabilityCount);

//获取到随机商品ID

String prizeId = prizesId[index];

优化方法

设计思路

以上方法如果大概率的话,是很吃内存的,整理优化为一下方法:

ff890460e3fe6895416d64840985d.jpg

使用范围算法

//定义中奖率分母 百分之

int probabilityCount = 100;

//最小概率值

String min = "min";

//最大概率值

String max = "max";

Integer tempInt = 0;

//待中奖商品数组

Map> prizesMap = new HashMap<>();

//获取商品列表

List prizeInfoList = prizeInfoService.getPrizeInfo();

for (AdPrizeInfo prize : prizeInfoList) {

Map oddsMap = new HashMap<>();

//最小概率值

oddsMap.put(min,tempInt);

tempInt = tempInt + prize.getOdds();

//最大概率值

oddsMap.put(max,tempInt);

prizesMap.put(prize.getId(),oddsMap);

}

//随机一个数字

int index = (int) (Math.random() * probabilityCount);

AdPrizeInfo prizeInfo = null;

Set prizesIds = prizesMap.keySet();

for(String prizesId : prizesIds){

Map oddsMap = prizesMap.get(prizesId);

Integer minNum = oddsMap.get(min);

Integer maxNum = oddsMap.get(max);

//校验index 再哪个商品概率中间

if(minNum <= index && maxNum > index){

prizeInfo = prizeInfoService.selectByPrimaryKey(prizesId);

break;

}

}

//如果为空,则没中奖

if(prizeInfo == null){

prizeInfo = null;

}

这篇关于android随机抽奖代码_幸运大转盘抽奖 抽奖算法 程序实现逻辑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

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

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

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示