利用一个产生随机数的函数生成另一个产生随机数的函数

这篇博客分享了如何利用已有的随机数生成函数,如Rand5(),构造出新的随机数生成函数,如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;
}

int main()
{
	for (int i = 0 ; i < 100 ; i++)
	{
		cout<<Rand5()<<" ";
	}
	cout<<endl;
	for (int j = 0 ; j < 100 ; j++)
	{
		cout<<Rand7()<<" ";
	}
	cout<<en
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值