按概率生成随机结果,自己控制字符结果的生成类似彩票系统

2023-11-23 04:10

本文主要是介绍按概率生成随机结果,自己控制字符结果的生成类似彩票系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 目录
  • 定义概率集
  • 改造概率集
  • 随机生成概率集索引
  • 通过率索查找元素
  • 测试数据验证
  • 加入战队
    • 微信公众号

随机数是专门的随机实验的结果,在统计学的不同技术中需要使用随机数,比如在从统计总体中抽取有代表性的样本的时候,或者在将实验动物分配到不同的实验组的过程中,或许在进行蒙特卡罗模拟法计算的时候等等。产生随机数有多种不同的方法,这些方法被称为随机数发生器。随机数量重要的特性是:他所产生的后面的那个数与前面的那个数毫无联系。

今天我们讨论的问题就是基于随机数展开的。总所周知,彩票就是一种随机的发生,但是在这随机的表面下实际上是一种有目的行的控制的随机。简而言之是在大概率下的随机生成

定义概率集
改造概率集
随机生成概率集索引
通过率索查找元素
测试数据验证
加入战队

目录

定义概率集


/*** 定义一个连续集合* 集合中元素x满足:(minElement,maxElement]* 数学表达式为:minElement < x <= maxElement**/
public class ContinuousList {private double minElement;private double maxElement;public ContinuousList(double minElement, double maxElement){if(minElement > maxElement){throw new IllegalArgumentException("区间不合理,minElement不能大于maxElement!");}this.minElement = minElement;this.maxElement = maxElement;}/*** 判断当前集合是否包含特定元素* @param element* @return*/public boolean isContainKey(double element){boolean flag = false;if(element > minElement && element <= maxElement){flag = true;}return flag;}}

首先通过一个类ContinuousList来存储概率集的对象,用来表示在宿主轴1上。这里友情提醒一下,这里的概率集并不一定需要概率和为100% , 这里的概率提供方只需要提供一个权重就行了,我们在投射到宿主轴2上的时候自动会一次补全的,最后也是通过随机数看在那块权重对应的索引上的。就好想将权重类似铺砖一样依次铺满就行,然后随机扔一个石子看在那一块就行。

构造概率因子

概率平铺示意图

示意图

改造概率集

上面我们提到供应方提供的是权重,图一提供{10,10,5,5,30,10,5,25},总和为100(不是必须是100,这里100只是为了方便观测)这些表示的意思是生成第0位的该路为10/100=10%。现在加入我们有一个数组集合为{“a”,"b","c","d","e","f","g","h"}这八个字符。那么现在通过图一的构造,那么生成a~h的概率分别是{10%,10%,5%,5%,30%,10%,5%,25%}
那么如何通过权重转变为概率的呢。

  • 首先第一个元素权重为10,则其在宿主轴3上的分布范围为 0~10
  • 第二个元素权重10,对应的分布范围则为10~20
  • 第三个元素权重5,对应的分布范围则为20~25
  • 第四个元素权重5,对应的分布范围则为25~30
  • 第五个元素权重30,对应的分布范围则为30~60
  • 第六个元素权重10,对应的分布范围则为60~70
  • 第七个元素权重5,对应的分布范围则为70~75
  • 第八个元素权重25,对应的分布范文责问75~100

分布图

随机生成概率集索引


/*** 进行抽奖操作* 返回:奖品的概率list集合中的下标*/
public int randomColunmIndex(){int index = -1;Random r = new Random();double d = r.nextDouble() * maxElement;  //生成0-1间的随机数if(d == 0d){d = r.nextDouble() * maxElement;     //防止生成0.0}int size = lotteryList.size();for(int i = 0; i < size; i++){ContinuousList cl = lotteryList.get(i);if(cl.isContainKey(d)){index = i;break;}}if(index == -1){throw new IllegalArgumentException("概率集合设置不合理!");}return index;}

现在我们的宿主轴4已经构建好了,下面我们基于各个读者使用的语言生成0~1的随机数,然后按宿主轴5的比例放大至宿主轴6上。
例如: 随机生成0.5238 , 上述的宿主轴7长度是100 , 则此次生成的随机数0.5238对应宿主轴8上的52.38。52.38在30~60这个区间范围,所以此次随机生成的所以则为30~60对应的索引3(从0开始)

通过率索查找元素

上面52.38对应的概率集合中的索引是3,这里就解释了为什么概率集和结果集个数要对应上。因为通过宿主轴9我们生成了索引,概率集和结果集个数一样就保证了我们一定会获取到结果。通过索引3我们获取到的结果是d

测试数据验证

上面介绍了改算法的执行原理集流程,纸上得来终觉浅,现在我们将通过该算法随机生成100000条数据,生成的同时我们加上统计数量的算法。最后我们对比下计划生成的概率和实际生成概率就可以验证改算法了。

结果

到这里也该和读者说再见了,今天的按概率生成随机数就结束了,如果读者对随机数生成原理感兴趣的话,可以对次软文拥有者建议,后续我会根据情况进行原理分析的。

加入战队

源码提供

个人网站

[个人微信] zxh870775401

微信公众号

微信公众号


  1. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  2. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  3. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  4. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  5. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  6. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  7. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  8. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

  9. 宿主轴是将概率的整体分布抽象为一条射线,不同的概率投影在该条射线上。↩

转载于:https://www.cnblogs.com/zhangxinhua/p/11345989.html

这篇关于按概率生成随机结果,自己控制字符结果的生成类似彩票系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热