等概率生成随机数问题解析
来源:互联网 发布:剑网三捏脸数据怎么看 编辑:程序博客网 时间:2024/05/17 23:03
1.rand5()求rand7()问题,等概率问题解决办法,构造等概率的随机数范围让这个范围比7的倍数大然后截取7的倍数那一段除以7取余如下
int i=0;
while(i<20)
{
i=5*rand5()+rand5();//5*rand5()产生0 5 10 15 20各数出现概率均为,rand5()出现0 1 2 3 4各数概率均为20%,相加出现0-24各数概率20%
}
return (i+1)%7;//取出0-24中0-20这一段共21个数改变范围为1-21除以7取余即可
解法二:通过矩阵构造出等概率的模7数据列表
int a[5][5]={
0,1,2,3,4,
5,6,0,1,2,
3,4,5,6,0,
1,2,3,4,5,
6,7,7,7,7};
int i;
int j;
int result=7;
while(result==7)
{
i=rand5();
j=rand5();
result=a[i][j];//等概率的选择矩阵中的数据,若不是模7的数据则继续选择
}
}
- #include <iostream>
- #include <stdio.h>
- using namespace std;
- int rand5()
- {
- return (rand()%5+1);
- }
- void main()
- {
- int a;
- while((a=rand5()*5+rand5())>26);
- cout<< (a-3)/3<<endl;
- }
代码解释:
1. 通过 rand5()*5+rand5() 产生 6 7 8 9 10 11 …… 26,27 28 29 30 这25个数,每个数的出现机率相等
2. 只需要前面 3*7 个数,所以舍弃后面的4个数
3. 将 6 7 8 转化为 1,9 10 11 转化为 2,……,24 25 26 转化为 7。公式是 (a-3)/3
0 0
- 等概率生成随机数问题解析
- 等概率随机数问题
- 总结篇:面试中 随机数"等概率"vs"不等概率"生成问题
- 单遍历取等概率随机数问题
- 随机数---等概率,特殊概率
- 等概率获取随机数
- 面试题常见算法之等概率生成随机数
- 概率、随机数、随机数生成函数
- 按概率生成随机数
- 按照概率生成随机数
- 【转】C++生成随机数——生成任意范围内的等概率随机数
- 【转】 C++生成随机数——生成任意范围内的等概率随机数
- C++生成随机数——生成任意范围内的等概率随机数
- C++随机数--——生成任意范围内等概率随机数“足够好”的做法
- 概率条件下随机数的生成
- python按概率生成随机数
- 随机数及按照概率生成随机数
- 生成等概率
- Ubuntu上安装ibus
- 2011年02月15日的日记
- 我的青春谁做主(经典台词)
- (无聊)53句话
- 思考
- 等概率生成随机数问题解析
- 子串最大和
- 2--2有序的结构体数组
- 面试题网址
- it公司笔试题(转载)
- 阿里巴巴笔试题1(转载)
- 阿里巴巴笔试题2(转载)
- 字符串的相似度-最小操作次数(转载…
- linux 下的lsof 命令