安彧孑 2022-10-28 17:43 采纳率: 66.7%
浏览 252
已结题

一道C语言的算法问题

有一个函数 foo() 能够返回 1~5的随机数,那么请使用 foo(),设计一个程序实现 1~n的随机数。要求输出的随机数足够随机,有机会取值1~n的任意数字。前几天面试遇到的,没看懂什么意思啊

  • 写回答

10条回答 默认 最新

  • 超级虚空 2022-10-28 17:56
    关注

    换一个角度,如果foo返回的是0-1的随机数,这时我们只需要建立一个二进制的随机数生成器就可以满足要求了。

    现在foo返回1-5,那么需要减1,建立5进制随机数生成器数,产生的随机数最大值必须大于等于n,如果生成的随机数超过n就重新生成一次,直到小于n。

    或者直接生成5进制下非常非常大的数,然后对n取余数也是可以的,不过需要注明可以忽略。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(9条)

报告相同问题?

问题事件

  • 系统已结题 11月10日
  • 已采纳回答 11月2日
  • 赞助了问题酬金15元 10月28日
  • 创建了问题 10月28日