关于面试中经常出现的根据一个随机数构造另外的随机数的解法

本文总结了面试中常见的根据已有随机数生成器(如Rand5、rand7)构造新随机数生成器(如Rand7到Rand10)的解法。通过两次调用概率函数并进行适当舍弃,可以实现等概率生成目标范围内的随机数。文中给出了具体的代码示例,并提及了一种更简洁的解决方案。
摘要由CSDN通过智能技术生成

原文地址:关于面试中经常出现的根据一个随机数构造另外的随机数的解法

最近做了一些Tencent及几家公司的面试题,发现有一种关于产生随机数的类型的题目。看到多有大牛们做出来,而且效率很高,也有不知道怎么做的,最近根据几个产生随机数的题目整理一下,发现所有的类似题目可以用一种万能钥匙解决。故分享,欢迎发表不同看法,欢迎吐槽。

题目一:给定能随机生成整数1到5的函数,写出能随机生成整数1到7的函数。

利用随机函数rand()函数生成一个等概率随机生成整数1到5的函数Rand5(),然后根据Rand5()生成Rand7(),代码如下:

#include <iostream>
using namespace std;
int Rand5()
{
	int n =1 + rand()%5;
	return n;
}
int Rand7()
{	
	int n ,tmp1 ,tmp2;	
	do 
	{
		tmp1 = Rand5();
	    tmp2 = Rand5();
		n = (tmp1-1)*5+tmp2;//n是可以取1~25的随机的数。
	} while (n>21);//当n>21舍去,这样n只能取1~21,对7取模就能取1~7之间的随机数

	return 1+n%7;
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值