Chalet37 2015-05-06 01:50 采纳率: 66.7%
浏览 3326
已采纳

求给出一个生成n个和为1,且每个数都在[0,1]间的随机数的算法

同题,有伪码就好了,或者其他什么代码都可以。要求生成的随机数分布不会有明显的集中,比如最后几个随机数总是近似为零

  • 写回答

6条回答 默认 最新

  • Tiger_Zhao 2015-05-06 05:57
    关注

    这不很简单吗。
    理论上:先生成n个随机数,求总和得S,每个数都除以S,就保证和为1。
    实现上:
    1)除之前先判断一下S是否为0(随机算法太妖了吧),是0就重来。
    2)考虑到小数的精度问题,最后一个数修正为 1-(前n-1个数的和)。

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

报告相同问题?

悬赏问题

  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?
  • ¥15 matlab(相关搜索:紧聚焦)