haskell产生随机数的问题

发布于 2022-08-13 05:20:51 字数 168 浏览 12 评论 1

rollDice n = getStdRandom (randomR (1,n)) :: IO Integer
则 mapM (x->rollDice 33) [1..6] 将产生6个[1..33]中的随机数, 但产生的随机数中可能有重复的, 如何简单产生指定范围中不重复的随机数呢?

谢谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

蓝海 2022-08-17 02:05:55

原帖由 sw2wolf 于 2009-4-29 08:24 发表
rollDice n = getStdRandom (randomR (1,n)) :: IO Integer
则 mapM (x->rollDice 33) [1..6] 将产生6个[1..33]中的随机数, 但产生的随机数中可能有重复的, 如何简单产生指定范围中不重复的随机数呢?

使用 randomRs,然后在取的时候自己把重复的过滤掉。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文