leetcode470. 用 Rand7() 实现 Rand10()

在这里插入图片描述
思路

  1. 如果是10做7的话,构成[0-7*n]大于7的舍弃就可以
  2. 如果是7做10,还是要构成[0-10*n]大于10的倍数舍弃就可以
  3. 公式rand_X(),rand_Y(),可以生成[1-x],[1-y]的随机数,(rand_X() - 1) × Y + rand_Y() ==> 可以等概率的生成[1, X * Y]范围的随机数(rand7-1)*7+rand7===>[1-49]那么超出倍数范围的舍弃就可以了
a\b1234567
01234567
7891011121314
1415161718192021
21
28
35
4249
int rand10() {

    while(1){
    int a = (rand7()-1)*7;
    int b = rand7();
    int c = a+b;
    if(c<=40)
        return c%10+1;
    }
    return 0;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值