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

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使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

SpringBoot集成iText快速生成PDF教程

《SpringBoot集成iText快速生成PDF教程》本文介绍了如何在SpringBoot项目中集成iText9.4.0生成PDF文档,包括新特性的介绍、环境准备、Service层实现、Contro... 目录SpringBoot集成iText 9.4.0生成PDF一、iText 9新特性与架构变革二、环

idea-java序列化serialversionUID自动生成方式

《idea-java序列化serialversionUID自动生成方式》Java的Serializable接口用于实现对象的序列化和反序列化,通过将对象转换为字节流来存储或传输,实现Serializa... 目录简介实现序列化serialVersionUID配置使用总结简介Java.io.Seripyth

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

C#自动化生成PowerPoint(PPT)演示文稿

《C#自动化生成PowerPoint(PPT)演示文稿》在当今快节奏的商业环境中,演示文稿是信息传递和沟通的关键工具,下面我们就深入探讨如何利用C#和Spire.Presentationfor.NET... 目录环境准备与Spire.Presentation安装核心操作:添加与编辑幻灯片元素添加幻灯片文本操

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信