如何产生不重复的随机数?
时 间:2008-09-06 08:08:59
作 者:fan0217 ID:3202 城市:绵阳
摘 要:如何产生不重复的随机数?
正 文:
先创建个类模块:Random
类模块代码如下:
CODE:
Dim c As Collection
'初始化,定义产生随机数的最小值和最大值
Public Sub Init(min As Integer, max As Integer)
Set c = New Collection
Dim i As Integer
For i = min To max
c.Add i
Next
End Sub
'产生不重复的随机数
Public Function RandomNext() As Integer
Dim i As Integer
Dim number As Integer, upperbound As Integer
upperbound = c.Count
If upperbound > 0 Then
number = Int((upperbound) * Rnd + 1)
RandomNext = CInt(c.Item(number))
c.Remove (number)
Else
RandomNext = 0
End If
End Function
Private Sub Class_Terminate()
Set c = Nothing
End Sub
测试:
CODE:
Dim r As New Random
Sub Test() '请先运行Init
Dim i As Integer
For i = 0 To 10
Debug.Print r.RandomNext
Next
End Sub
Sub Init()
r.Init 1, 100
End Sub
这里使用集合来实现的,也可以用哈希表来做,道理差不多。哈希表需要自己定义类模块。
Access软件网QQ交流群 (群号:483923997) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access两种方式实现即时更...(03.01)
- Access隐藏与显示lacc...(01.12)
- 【Access高效办公】将每个...(12.23)
- Access21点游戏源代码(12.13)
- 【Access窗体导出Exce...(11.15)
- 【Access开发】Acces...(11.14)
- 通过Access宏录入数据到选...(11.10)
- 用DLOOKUP函数将需求表中...(10.31)
- Access日期区间段查询数据...(10.25)
学习心得
最新文章
- Access快速开发平台--在WI...(03.08)
- 使用SQL语句删除xscj表中学号...(03.08)
- Access快速开发平台进销存教程...(03.07)
- Access快速开发平台--frm...(03.06)
- 【Access删除查询】删除数字最...(03.06)
- Access快速开发平台进销存教程...(03.05)
- Access快速开发平台进销存教程...(03.04)
- Access快速开发平台--IsL...(03.02)
- Access两种方式实现即时更新月...(03.01)
- Access开发的资金管理系统;基...(02.29)