随机数模拟投100次硬币,求正面朝上的次数并输出解决实例假设值为1时是正面向上 输出结果如下 42 45 50 47 53 48 49 50 42 45 Private Sub Command2_Click() Dim str1 As String Dim intNum As Integer Dim i As Integer intNum = 0 For i = 0 To 99 str1 = CStr(Int(Rnd() * 2)) If str1 = "1" Then intNum = intNum + 1 End If Next Debug.Print intNum End Sub
如果发现数经常重复,可以用Randomize Timer来进行初始化种子。
随机列出0-100之间的数dim intVal as integerintval=int(rnd()*100) debug.print intval
SoHo_Andy(冰):不是很明白意思啊,:)
呵呵,给你的就是一个使用RND()函数的实例啊 For i = 0 To 99 str1 = CStr(Int(Rnd() * 2)) If str1 = "1" Then intNum = intNum + 1 End If Next意思是用rnd()函数产生一个0和1之间的随机数
输出结果如下
42
45
50
47
53
48
49
50
42
45 Private Sub Command2_Click()
Dim str1 As String
Dim intNum As Integer
Dim i As Integer
intNum = 0
For i = 0 To 99
str1 = CStr(Int(Rnd() * 2))
If str1 = "1" Then
intNum = intNum + 1
End If
Next
Debug.Print intNum
End Sub
debug.print intval
For i = 0 To 99
str1 = CStr(Int(Rnd() * 2))
If str1 = "1" Then
intNum = intNum + 1
End If
Next意思是用rnd()函数产生一个0和1之间的随机数
小于 0 每次都使用 number 作为随机数种子得到的相同结果。
大于 0 序列中的下一个随机数。
等于 0 最近生成的数。
省略 序列中的下一个随机数。
说明Rnd 函数返回小于 1 但大于或等于 0 的值。number 的值决定了 Rnd 生成随机数的方式。对最初给定的种子都会生成相同的数列,因为每一次调用 Rnd 函数都用数列中的前一个数作为下一个数的种子。在调用 Rnd 之前,先使用无参数的 Randomize 语句初始化随机数生成器,该生成器具有根据系统计时器得到的种子。为了生成某个范围内的随机整数,可使用以下公式:Int((upperbound - lowerbound + 1) * Rnd + lowerbound)这里,upperbound 是随机数范围的上限,而 lowerbound 则是随机数范围的下限。注意 若想得到重复的随机数序列,在使用具有数值参数的 Randomize 之前直接调用具有负参数值的 Rnd。使用具有同样 number 值的 Randomize 是不会得到重复的随机数序列的。