九章算法面试题13 随机数生成器
来源:互联网 发布:新闻app源码 编辑:程序博客网 时间:2024/06/11 17:05
九章算法官网-原文网址
http://www.jiuzhang.com/problem/13/
题目
有一个随机数生成器,每次等概率的返回1到5中的一个整数。现在需要你利用这个随机数生成器来设计一个新的随机数生成器,每次可以等概率的返回1到7中的一个整数。
解答
随机两次rand(5)相当于随机一次rand(25),将前21个数三三一组分为7组,如果得到的数<=21,则返回对应组号; 如果>21则重复上述过程,直到得到的数<=21。
时间复杂度为O(2*21/25 + 4 * 21/25 * 4/25 + 6 * 21/25 * 4/25 * 4/25 … ) = O(1)
面试官角度
这个题目的解题思路有一点智力题的感觉。因为5和7互质,所以无法找到5^n被7整出。一个基本的陷阱是,调用两次rand(5)得到的是rand(25)而不是rand(10)。
0 0
- 九章算法面试题13 随机数生成器
- 九章算法面试题3 找坏球
- 九章算法面试题28 链表找环
- 九章算法面试题71 平方根
- 九章算法面试题74 中位数
- 九章算法 | Facebook 面试题 : Backpack VI 背包算法
- 面试题之九章算法 字符串编辑距离
- 九章算法——面试题思路
- 九章算法面试题1 落单的数
- 九章算法面试题2 抄书问题
- 九章算法面试题4 索引比例
- 九章算法面试题5 有序数组合并
- 九章算法面试题6 负载均衡
- 九章算法面试题7 分层遍历二叉树
- 九章算法面试题10 赛马问题
- 九章算法面试题11 递增矩阵
- 九章算法面试题12 最大子区间/矩阵
- 九章算法面试题14 超过一半的数
- Bean作用域的配置以及 Spring各种注入方式实例 list set map props
- eclipse maven mahout环境搭建
- 我是如何做原型设计的
- Bluemix云平台实践:DevOps
- Android---38---SQLiteOpenHelper类
- 九章算法面试题13 随机数生成器
- 使用MediaTracker加载及显示图像
- poj 1625
- repo的小结
- 如何在Mac OS X上安装 Ruby运行环境
- fdfdas
- 提高第21课时,实践3,有序数组中插入数据 (第2种方法)
- 鸡啄米VC++2010系列1(解决方案与工程)
- 设计模式学习之设计模式原则(二):依赖倒置原则和接口隔离原则