安彧孑 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日

悬赏问题

  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗