vba里Rnd函数的参数是什么意思?

我查阅了帮助文档,对Rnd(Number)的括号里的Number值不是很明白小于0每次都使用number作为随机数种子得到的相同结果。大于0序列中的下一个随机数。等于0最... 我查阅了帮助文档,对Rnd(Number)的括号里的Number值不是很明白
小于 0 每次都使用 number 作为随机数种子得到的相同结果。
大于 0 序列中的下一个随机数。
等于 0 最近生成的数。
省略 序列中的下一个随机数。

大于0和省略,是不是一回事?
等于0是不是代表如果生成的随机结果为x,那么下次随机数就以x为种子值?
小于0是不是始终以number作为种子值?
展开
 我来答
帐号已注销
高粉答主

2019-08-11 · 关注我不会让你失望
知道小有建树答主
回答量:1346
采纳率:100%
帮助的人:35.5万
展开全部

Rnd函数的参数是Visual Basic中随机函数。

格式:Rnd(<数值表达式>)

功能:求[0,1)之间的一个随机数

语法:

Rnd[(number)]

如果 number 的值是 Randomize 生成

小于 0 ,每次都使用 number 作为随机数种子得到的相同结果。

大于 0 ,以上一个随机数为种子产生下一个随机数。

等于 0 ,产生与最近生成的随机数相同的随机数。

省略, 以上一个随机数为种子产生下一个随机数。


扩展资料

Rnd 函数返回小于 1 但大于或等于 0 的值。

number 的值决定了 Rnd 生成随机数的方式。

对最初给定的种子都会生成相同的数列,因为每一次调用 Rnd 函数都用数列中的前一个数作为下一个数的种子。

在调用 Rnd 之前,先使用无参数的 Randomize语句初始化随机数生成器(若带参数,则产生由参数对应的一个特定序列的随机数),该生成器具有根据系统计时器得到的种子。

为了生成某个范围内的随机整数,可使用以下公式:

Int((upperbound - lowerbound + 1) * Rnd + lowerbound)

这里,upperbound 是随机数范围的上限,而 lowerbound 则是随机数范围的下限。

注意 若想得到重复的随机数序列,在使用具有数值参数的 Randomize 之前直接调用具有负参数值的 Rnd。使用具有同样 number 值的 Randomize 是不会得到重复的随机数序列的。

qiaoxiaomao
推荐于2017-09-25 · TA获得超过368个赞
知道小有建树答主
回答量:472
采纳率:0%
帮助的人:408万
展开全部
大于0的情况下可以省略,所以是一回事。
等于0的情况下,你说的不对。
是这样的,比如: Rnd() ‘结果为0.3325521
Rnd(0) ’结果同样为0.3325521,和最近的一次Rnd()生成的结果一样
小于0的情况你说的对,如果种子值不变,那么生成的随机数也不变。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
艳阳高照的午后
推荐于2017-09-21 · TA获得超过1万个赞
知道大有可为答主
回答量:1.2万
采纳率:97%
帮助的人:4837万
展开全部
  rnd函数
  Visual Basic中随机函数
  格式:Rnd(<数值表达式>)
  功能:求[0,1)之间的一个随机数
  语法:Rnd[(number)]
  如果 number 的值是 Randomize 生成
  小于 0 ,每次都使用 number 作为随机数种子得到的相同结果。
  大于 0 ,以上一个随机数为种子产生下一个随机数。
  等于 0 ,产生与最近生成的随机数相同的随机数。
  省略, 以上一个随机数为种子产生下一个随机数。
  说明:
  Rnd 函数返回小于 1 但大于或等于 0 的值。
  number 的值决定了 Rnd 生成随机数的方式。
  对最初给定的种子都会生成相同的数列,因为每一次调用 Rnd 函数都用数列中的前一个数作为下一个数的种子。
  在调用 Rnd 之前,先使用无参数的 Randomize语句初始化随机数生成器(若带参数,则产生由参数对应的一个特定序列的随机数),该生成器具有根据系统计时器得到的种子。
  为了生成某个范围内的随机整数,可使用以下公式:
  Int((upperbound - lowerbound + 1) * Rnd + lowerbound)
  这里,upperbound 是随机数范围的上限,而 lowerbound 则是随机数范围的下限。
  注意 若想得到重复的随机数序列,在使用具有数值参数的 Randomize 之前直接调用具有负参数值的 Rnd。使用具有同样 number 值的 Randomize 是不会得到重复的随机数序列的。
  函数示例:
  本示例使用 Rnd 函数随机生成一个 1 到 6 的随机整数。
  Dim MyValue
  MyValue = Int((6 * Rnd) + 1) ' 生成 1 到 6 之间的随机数值 ,这里的int 是把后面产生的小数转换成整数!
  由于Rnd是[0,1),(6*Rnd)+1为[1,7)。int是求不大于number 的最大整数,所以得出1~6的随机数
  
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式