上海站 | 高性能计算之GPU CUDA培训

4月13-15日

三天密集式学习  快速带你晋级
阅读全文
>

正文共2508个字,1张图,预计阅读时间7分钟。

题目描述

给你一个能生成1到5随机数的函数,用它写一个函数生成1到7的随机数。 (即,使用函数rand5()来实现函数rand7())。

思路

rand5可以随机生成1,2,3,4,5;rand7可以随机生成1,2,3,4,5,6,7。 rand5并不能直接产生6,7,所以直接用rand5去实现函数rand7似乎不太好入手。 如果反过来呢?给你rand7,让你实现rand5,这个好实现吗?

一个非常直观的想法就是不断地调用rand7,直到它产生1到5之间的数,然后返回。 代码如下:

def rand5():

res = 6    while res > 5:

res = rand7()

return res

等等,这个函数可以等概率地产生1到5的数吗?首先,它确确实实只会返回1到5这几个

数, 其次,对于这些数,都是由Rand7等概率产生的(1/7),没有对任何一个数有偏袒, 直觉告诉我们,Rand5就是等概率地产生1到5的。事实呢?让我们来计算一下, 产生1到5中的数的概率是不是1/5就OK了。比如说,让我们来计算一下Rand5生成1 的概率是多少。上面的函数中有个while循环,只要没生成1到5间的数就会一直执行下去。

因此,我们要的1可能是第一次调用Rand7时产生,也可能是第二次,第三次,…第n次。 第1次就生成1,概率是1/7;第2次生成1,说明第1次没生成1到5间的数而生成了6,7, 所以概率是(2/7)*(1/7),依次类推。生成1的概率计算如下:

P(x=1)=1/7 + (2/7) * 1/7 + (2/7)^2 * 1/7 + (2/7)^3 * 1/7 + ...

=1/7 * (1 + 2/7 + (2/7)^2 + ...) // 等比数列

=1/7 * 1 / (1 - 2/7)

=1/7 * 7/5

=1/5

上述计算说明Rand5是等概率地生成1,2,3,4,5的(1/5的概率)。从上面的分析中, 我们可以得到一个一般的结论,如果a > b,那么一定可以用Randa去实现Randb。其中, Randa表示等概率生成1到a的函数,Randb表示等概率生成1到b的函数。

解答

先给出rand5()的python代码:

import randomdef rand5():    return random.randint(1, 5)

回到正题,现在题目要求我们要用Rand5来实现Rand7,只要我们将Rand5 映射到一个能产生更大随机数的Randa,其中a > 7,就可以套用上面的模板了。 这里要注意一点的是,你映射后的Randa一定是要满足等概率生成1到a的。比如,

Rand5() + Rand5() - 1

上述代码可以生成1到9的数,但它们是等概率生成的吗?不是。生成1只有一种组合: 两个Rand5()都生成1时:(1, 1);而生成2有两种:(1, 2)和(2, 1);生成6更多。 它们的生成是不等概率的。那要怎样找到一个等概率生成数的组合呢?

我们先给出一个组合,再来进行分析。组合如下:

5 * (Rand5() - 1) + Rand5()

Rand5产生1到5的数,减1就产生0到4的数,乘以5后可以产生的数是:0,5,10,15,20。 再加上第二个Rand5()产生的1,2,3,4,5。我们可以得到1到25, 而且每个数都只由一种组合得到,即上述代码可以等概率地生成1到25。OK, 到这基本上也就解决了。

套用上面的模板,我们可以得到如下代码:

def rand7():

res = 8

while res > 7:

res = 5 * (rand5() - 1) + rand5()

return res

上面的代码有什么问题呢?可能while循环要进行很多次才能返回。 因为Rand25会产生1到25的数,而只有1到7时才跳出while循环, 生成大部分的数都舍弃掉了。这样的实现明显不好。我们应该让舍弃的数尽量少, 于是我们可以修改while中的判断条件,让x与最接近25且小于25的7的倍数相比。 于是判断条件可改为x > 21,于是x的取值就是1到21。 我们再通过取模运算把它映射到1-7即可。代码如下:

def rand7():

res = 25

while res > 21:

res = 5 * (rand5() - 1) + rand5()

return res % 7 + 1

这个实现就比上面的实现要好,并且可以保证等概率生成1到7的数。

让我们把这个问题泛化一下,从特殊到一般。现在我给你两个生成随机数的函数Randa, Randb。Randa和Randb分别产生1到a的随机数和1到b的随机数,a,b不相等 (相等就没必要做转换了)。现在让你用Randa实现Randb。

通过上文分析,我们可以得到步骤如下:

1、如果a > b,进入步骤2;否则构造Randa2 = a * (Randa – 1) + Randa, 表示生成1到a2 随机数的函数。如果a2 仍小于b,继教构造 Randa3 = a * (Randa2 – 1) + Randa…直到ak > b,这时我们得到Randak , 我们记为RandA。

2、步骤1中我们得到了RandA(可能是Randa或Randak ),其中A > b

验证

一百万次随机生成,查看各个数字出现概率
代码如下:

import randomdef rand5():    return random.randint(1, 5)

def rand7():    res = 25    while res > 21:        res = 5 * (rand5() - 1) + rand5()

return res % 7 + 1d = {}for i in range(1, 8):    d[i] = 0for i in range(1, 1000001):    d[rand7()] += 1for i in range(1, 8):    print(i, '出现的概率是:', float(d[i] / 1000000))

结果

1 出现的概率是: 0.142897

2 出现的概率是: 0.142651

3 出现的概率是: 0.142795

4 出现的概率是: 0.142416

5 出现的概率是: 0.142414

6 出现的概率是: 0.14348

7 出现的概率是: 0.143347

结论:概率相等,实验验证成功

参考链接:https://blog.csdn.net/wangruitao1991/article/details/51678815

原文链接:https://www.jianshu.com/p/f540a428d190

查阅更为简洁方便的分类文章以及最新的课程、产品信息,请移步至全新呈现的“LeadAI学院官网”:

www.leadai.org

请关注人工智能LeadAI公众号,查看更多专业文章

大家都在看


LSTM模型在问答系统中的应用

基于TensorFlow的神经网络解决用户流失概览问题

最全常见算法工程师面试题目整理(一)

最全常见算法工程师面试题目整理(二)

TensorFlow从1到2 | 第三章 深度学习革命的开端:卷积神经网络

装饰器 | Python高级编程

今天不如来复习下Python基础

今日头条面试题:生成随机数(根据rand5()生成rand7())相关推荐

  1. web前端整套面试题(二)--今日头条面试题

    12道单选,7道不定项选择,2道编程题 一.单选(12题) 1.[单选题]在HTML中,( )可以在网页上通过链接直接打开邮件客户端发送邮件. A.<a href="telnet:mi ...

  2. python生成随机数方法_Python生成随机数的方法

    如果你对在Python生成随机数与random模块中最常用的几个函数的关系与不懂之处,下面的文章就是对Python生成随机数与random模块中最常用的几个函数的关系,希望你会有所收获,以下就是这篇文 ...

  3. linux 生成随机数 命令,Linux生成随机数的多种方法

    8种机械键盘轴体对比 本人程序员,要买一个写代码的键盘,请问红轴和茶轴怎么选? 通过内部系统变量 $RANDOM 如果超过 5 位可以加个固定 10 位整数,然后进行求余.生成 400000~5000 ...

  4. python如何生成随机数_python如何生成随机数

    如果你对在Python生成随机数与random模块中最常用的几个函数的关系与不懂之处,下面的文章就是对Python生成随机数与random模块中最常用的几个函数的关系,希望你会有所收获,以下就是这篇文 ...

  5. Python生成随机数和numpy生成随机数

    生成随机数 使用random函数 random.random() 产生一个包含0不包含1之间的小数 random.randint(1,5) 产生一个包含开始和结束的整数 random.uniform( ...

  6. php生成随机数random,PHP生成随机数的方法实例分析

    通常情况下,当我们要生成一个随机字符串时,总是先创建一个字符池,然后用一个循环和mt_rand()或rand()生成php随机数,从字符池中随机选取字符,最后拼凑出需要的长度. function ra ...

  7. c++ 病句 今日头条面试题

    试题描述: 为了提高文章质量,每一篇文章(假设全部都是英文)都会有m名编辑审核,每个编辑独立工作,会把觉得有问题的句子通过下标记录下来,比如[1,10],1表示病句的第一个字符,10表示病句的最后一个 ...

  8. python后台研发工程师面试题_今日头条面试题之后台Python研发

    1.自我介绍 2.看你简历中反爬虫技术使用了IP代理,那问一下这个IP代理是在哪个层实现的? 答:运输层,当初想着IP协议是在运输层就回答了运输层,其实傻的可以,IP协议中的IP是固定不变的,网络号+ ...

  9. 今日头条面试题,供大家参考

    1.给定一个只包含'(' 和')' 的字符串,找出最长的包含有效括号的字符串的长度 实例1: 输入:"(()" 输出:2 解释:最长有效括号字符串为 "()" ...

最新文章

  1. CUDA软件系统知识
  2. Android 画虚线 DashPathEffect 使用详解
  3. 矩阵运算最快的库有哪些
  4. python语言例子_【Python】SimPy的使用示例-Go语言中文社区
  5. 全球首款乘云而来的存储产品CDS诞生!
  6. (94)FPGA模块例化传递参数(input)
  7. C++和JNI的数据转换
  8. Input调用流程(好文)
  9. 四川绵阳:充分利用区块链等技术,为农民工证照办理提供线上便捷服务
  10. 云计算采用的各种虚拟化技术比较
  11. 深入理解计算机系统arch lab
  12. 涂鸦智能C/C++面经
  13. org.eclipse.core.runtime.IPath报错
  14. nodeJS 中文API node.js 中文文档
  15. 亚马逊测评项目有哪些风险
  16. 飞书深诺香港IPO招股书失效,营收、净利润均远不及木瓜移动
  17. PLSQL手动输入一个字符串,倒序打印输出字符串 , 如输入的是 abcd 打印输出 dcba
  18. ubuntu的bash参考手册
  19. 使用uglifyjs压缩JS文件
  20. 关于虚拟机搭建Hadoop的几个坑

热门文章

  1. zynq tcp如何从网口发数据_基于TCP/IP协议的电口通信
  2. java方法中的循环里的变量_Java中循环声明变量方法
  3. pinpoint性能检测工具搭建(APM)
  4. windows搭建SFTP服务器
  5. NBU调用crontab备份
  6. win10计算机无法复制文件,Win10系统下移动、复制、删除文件需要管理员权限的解决方法...
  7. oracle12c创建pdb用户6,ORACLE12C PDB创建默认表空间和用户语句
  8. web 服务器 内存 影响_工业环境软件套件 CODESYS web 服务器被曝严重的RCE漏洞
  9. css 3d魔方源代码,CSS3 3D环境实现立体 魔方效果代码(示例代码)
  10. Java并发编程之——并发集合