两种经典方法解决随机数生成问题--利用rand5得到rand7

2023-12-20 14:36

本文主要是介绍两种经典方法解决随机数生成问题--利用rand5得到rand7,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

两种方法:

  • 等概率得到0和1,然后利用二进制移位运算生成随机数
  • 基于N * (randN - 1) + randN,可以等概率地生成1-N*N之间的数字

利用rand5得到rand7 为例说明

# 一个函数可以实现1-5的随机数,设计另一个函数,实现1-7的随机数
class Rand2rand:def f5(self):return int(random.random() * 5) + 1# 等概率得到0和1def g01(self):while True:tmp = self.f5()if tmp < 3:return 0elif tmp > 3:return 1else:continue# 等概率得到0-6def f06(self):while True:tmp = (self.g01() << 2) + (self.g01() << 1) + (self.g01() << 0)if tmp == 7:continueelse:return tmp# 等概率得到1-7def f17(self):return self.f06() + 1# 验证结果def testRes(self, testTimes: int, rand_generator):arr = [0] * 7for i in range(testTimes):tmp = rand_generator()arr[tmp - 1] += 1for i in range(len(arr)):print(f'{i + 1} 出现了 {arr[i]} 次')def f17_2(self):# 5*(self.f5()-1) 等概率产生 0, 5, 10, 15, 20# self.f5() 等概率产生 1,2,3,4,5# 想加后,等概率产生 1-25# rand5()可以得到rand25()# rand25()可以得到rand625()# 总结,若randN() 可以随机生成1-N,那么N*(randN()-1) + randN() 可以随机生成 1-N**2randVal = 22while randVal > 21:randVal = 5 * (self.f5() - 1) + self.f5()return 1 + randVal % 7# 结果验证
if __name__ == '__main__':obj = Rand2rand()rand_gen1 = obj.f17rand_gen2 = obj.f17_2obj.testRes(1000000, rand_gen2)

class Rand2randGeneral:"""更一般的问题,给定一个可以产出[min, max]之间的等概率随机数函数,生成一个可以等概率生成[from, to]之间的随机数函数"""def __init__(self, min, max):self.min = minself.max = maxdef randomBox(self):diff = int(random.random() * (self.max - self.min + 1))randomValue = self.min + diffreturn randomValuedef getrand01(self):size = self.max - self.min + 1# 判断size 是奇数还是偶数isOdd = True if (size & 1) != 0 else Falsemid = int(size / 2)while True:ans = self.randomBox() - self.minif isOdd and ans == mid:continueelif ans < mid:return 0else:return 1def getRandGeneral(self, fromValue, toValue):if fromValue == toValue:return fromValuerangeVal = toValue - fromValuenum = 1while (1 << num) - 1 < rangeVal:num += 1while True:ans = 0for i in range(num):ans |= self.getrand01() << iif ans > rangeVal:continueelse:return ans + fromValue

这篇关于两种经典方法解决随机数生成问题--利用rand5得到rand7的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很