作者:iamlasong

VBA编程实现不重复随机数输出。VBA里的随机函数是RND,在工作表中随机函数是RAND,一字之差,可要记好了。RND取值范围是[0,1),意思是0和1之间的一个随机数,包含0,但不包含1。

1、用法

语法:Rnd[(number)]
  如果 number 的值是 Randomize 生成
  小于 0 ,每次都使用 number 作为随机数种子得到的相同结果。
  大于 0 ,以上一个随机数为种子产生下一个随机数。
  等于 0 ,产生与最近生成的随机数相同的随机数。
  省略, 以上一个随机数为种子产生下一个随机数(同大于0)。

说明:
  Rnd 函数返回小于 1 但大于或等于 0 的值。
  number 的值决定了 Rnd 生成随机数的方式。
  对最初给定的种子都会生成相同的数列,因为每一次调用 Rnd 函数都用数列中的前一个数作为下一个数的种子。
  在调用 Rnd 之前,先使用无参数的 Randomize 语句初始化随机数生成器(若带参数,则产生由参数对应的一个特定序列的随机数),该生成器具有根据系统计时器得到的种子。如果不使用Randomize 语句,那么每次执行程序时产生的随机数序列是相同的。

  Rnd 后面跟一个负数时,同样的参数可以得到完全相同的两个序列,例如,rnd -1执行后用rnd取1000个随机数,然后再执行rnd -1,然后再用rnd取1000个随机数,这1000个随机数和前面1000个完全相同。为了得到不同的序列,可以用不同的负数,也可以在rnd -1后面执行Randomize number。注意,要得到相同的序列,两次Randomize后面的number必须相同。这种方法用途之一就是用于加密和解密。
  关于产生相同的随机序列总结一下:1、Rnd(-1)后取随机数与再次执行Rnd(-1)取的随机数相同;2、Rnd(-1)后取随机数与再次执行Rnd(-2)取的随机数不同;3、Rnd(-1)和Randomize 1后取随机数与再次执行Rnd(-1)和Randomize 1取的随机数相同;4、Rnd(-1)和Randomize 1后取随机数与再次执行Rnd(-1)和Randomize 2取的随机数不同。

  为了生成某个范围内的随机整数,可使用以下公式:
  Int((upperbound - lowerbound + 1) * Rnd + lowerbound)
  这里,upperbound 是随机数范围的上限,而 lowerbound 则是随机数范围的下限。
  注意:若想得到重复的随机数序列,在使用具有数值参数的 Randomize 之前直接调用具有负参数值的 Rnd。使用具有同样 number 值的 Randomize 是不会得到重复的随机数序列的。

2、无重复随机数算法一

这是最简单的算法,每产生一个随机数,就和已有的比较,如果已经存在,则重新产生。比较适合从一个大范围里面抽出一小部分数据,比如,从题库中抽取试题。

' 产生20个1-100之间的不重复随机数
Public Sub RndNumberNoRepeat1()Dim RndNumber, temp(20), i, k, Maxrec As IntegerRandomize (Timer)           '初始化随机数生成器Maxrec = 100' 从A21开始输出随机数k = 0Do While k < 20RndNumber = Int(Maxrec * Rnd) + 1temp(k) = RndNumberCells(k + 21, 1) = RndNumberFor i = 0 To k - 1If temp(i) = RndNumber Then Exit ForNext iIf i = k Then k = i + 1'MsgBox "随机数:" & RndNumberLoopEnd Sub

3、无重复随机数算法二

这个算法比较巧妙,需要细细体会,才能知道真谛。这个算法不会重复产生随机数,但需要一个占位数组。比较适合输出范围之内所有数值的场合,比如,随机发牌。

' 产生20个1-100之间的不重复随机数
Sub RndNumberNoRepeat2()Dim RndNumber, TempArray(99), i As IntegerRandomize (Timer)           '初始化随机数生成器For i = 0 To 99            '产生包含1-100的不重复的随机数列TempArray(i) = iNext iFor i = 99 To 80 Step -1RndNumber = Int(i * Rnd)'从A21开始输出这些数字Cells(120 - i, 1) = TempArray(RndNumber) + 1TempArray(RndNumber) = TempArray(i)Next i
End Sub

4、无重复随机数算法三

这个算法使用字典对象完成去重复,和第一个算法差不多,但程序看上去简洁一点,嗯,起码新颖一点。

' 产生20个1-100之间的不重复随机数
Sub RndNumberNoRepeat3()
Dim d As Object   'New Dictionary
Dim s As IntegerRandomize (Timer)           '初始化随机数生成器
Set d = CreateObject("Scripting.Dictionary")Do Until d.Count = 20s = Int(Rnd * 100 + 1)d(s) = ""
Loop
[a21].Resize(d.Count, 1) = Application.Transpose(d.Keys)
End Sub

附:VBA中Dictionary对象使用小结

Dim dict

' 创建Dictionary
Set dict = CreateObject("Scripting.Dictionary")

' 增加项目
dict.Add "A", 300
dict.Add "B", 400
dict.Add "C", 500

' 统计项目数
n = dict.Count

' 删除项目
dict.Remove ("A")

' 判断字典中是否包含关键字
dict.exists ("B")

' 取关键字对应的值,注意在使用前需要判断是否存在key,否则dict中会多出一条记录
Value = dict.Item("B")

' 修改关键字对应的值,如不存在则创建新的项目
dict.Item("B") = 1000
dict.Item("D") = 800

' 对字典进行循环
k = dict.keys
v = dict.Items
For i = 0 To dict.Count - 1
key = k(i)
Value = v(i)
MsgBox key & Value
Next

' 删除所有项目
dict.Removeall

实例:

Sub 宏1()

Set dic = CreateObject("Scripting.Dictionary") '字典
For i = 1 To 10000
If Not i Like "*4*" Then
dic.Add i, "" '如果不包含“1”
End If
Next
Range("a2").Resize(dic.Count, 1) = Application.WorksheetFunction.Transpose(dic.keys) '从A2单元开始向下放置
End Sub

=========================================================================
又 Tranpose工作表函数的用法实例

'把一行多列的二维数组转换成一维数组
Sub test()
Dim arr, arrt
arr = Range("a1:j1")
arrt = WorksheetFunction.Transpose(WorksheetFunction.Transpose(arr))
Stop
End Sub
首先看看TRANSPOSE函数的基础用法。官方帮助说明,TRANSPOSE函数可返回转置单元格区域,即将行单元格区域转置成列单元格区域,反之亦然。

  TRANSPOSE函数语法是:TRANSPOSE(array)
  Array参数是需要进行转置的数组或工作表上的单元格区域。所谓数组的转置就是,将数组的第一行作为新数组的第一列,数组的第二行作为新数组的第二列,以此类推。

【VBA研究】VBA编程产生不重复随机数相关推荐

  1. vba随机抽取人名不重复_VBA编程实现不重复随机数输出

    作者:iamlasong VBA编程实现不重复随机数输出.VBA里的随机函数是RND,在工作表中随机函数是RAND,一字之差,可要记好了.RND取值范围是[0,1),意思是0和1之间的一个随机数,包含 ...

  2. base64编码 vba_【VBA研究】如何用Base64 编解码方法实现简单的加解密

    Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码,将数据变成字符串实现文本传输.由于编码简单,所以很容易实现,代码也是现成的.利用这个编码规则可以实现简单的加解密.编解码方 ...

  3. 程序员面试、算法研究、编程艺术、红黑树4大系列集锦与总结

    程序员面试.算法研究.编程艺术.红黑树4大经典原创系列集锦与总结 作者:July--结构之法算法之道blog之博主. 时间:2010年10月-2011年6月. 出处:http://blog.csdn. ...

  4. 5个数中取三个数组合 不重复 php,PHP产生不重复随机数的5个方法总结

    <:PHP产生不重复随机数的5个方法总结>要点: 本文介绍了:PHP产生不重复随机数的5个方法总结,希望对您有用.如果有疑问,可以联系我们. 随机数都有其用武之地.在最近接触的几个小项目中 ...

  5. 程序员面试、算法研究、编程艺术、红黑树、机器学习5大经典原创系列集锦与总结

    程序员面试.算法研究.编程艺术.红黑树.机器学习5大经典原创系列集锦与总结 (七月在线:https://www.julyedu.com/,面试 & 算法 & 机器学习在线课程) 作者: ...

  6. 神级:程序员面试、算法研究、编程艺术、红黑树、机器学习5大经典原创系列集锦与总结

    https://blog.csdn.net/v_JULY_v/article/details/6543438 https://blog.csdn.net/v_JULY_v/article/detail ...

  7. 【转自JULY大佬】程序员面试、算法研究、编程艺术、红黑树、机器学习5大系列集锦

    感谢原作者分享,转载自   https://blog.csdn.net/v_JULY_v/article/details/6543438 程序员面试.算法研究.编程艺术.红黑树.机器学习5大经典原创系 ...

  8. 程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大经典原创系列集锦与总结

    点击打开链接(具体详情 点击链接) 程序员面试.算法研究.编程艺术.红黑树.数据挖掘5大经典原创系列集锦与总结 (七月在线:点击打开链接,面试 & 算法 & 机器学习在线课程) 作者: ...

  9. 程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦

    程序员面试.算法研究.编程艺术.红黑树.数据挖掘5大经典原创系列集锦与总结 (编程艺术github:https://github.com/julycoding/The-Art-Of-Programmi ...

最新文章

  1. Window对象中setInterval()和setTimeout()的区别
  2. 以系统时间命名文件方法(C++)
  3. mysql日期函数 简书_ios怎样搭建php服务器
  4. SparkStreaming读取Kakfa数据时发生OffsetOutOfRangeException异常
  5. SAP S/4HANA使用ABAP获得生产订单的状态
  6. CSS实现导航条Tab切换的三种方法
  7. 魔兽世界工程学技能1-375冲级攻略
  8. 【OJ】洛谷红题题解锦集(Java语言描述)
  9. 充满男性荤段子的开源软件 DICSS 引发争议
  10. 【讨论】测试工程师能否作为一份终生职业?30岁+怎么办?
  11. Leetcode-字符串
  12. 深圳市云瑶信息科技有限公司
  13. Salesforce:下个财年营收我们有望突破100亿美元
  14. 计算机桌面自设提示语,如何在电脑桌面便签上设置每周五自动弹窗提醒?
  15. 【Android开发-4】进入实践,最喜欢折腾的计算器
  16. 高德地图 scale
  17. php时间计算,计算本周一或周日,上周一或周日,下周一
  18. 经典算法+Gif动图
  19. 富士胶片LTO磁带减排效益获认可;耀世星辉深度测试海外版语音社交产品“悦聊”CheerChat | 全球TMT...
  20. JavaWeb开发实现一个动态页面

热门文章

  1. 经济学基础(本)【3】
  2. Windows装机必备基础软件,都在这里了
  3. MSDN经典案例分析--PetShop
  4. Bootstrap 轻松实现选项卡
  5. iOS 7最佳实践:一个天气App案例
  6. python内置库有哪些_python 内置库
  7. 张一鸣这条微博,就……有点害人不浅
  8. 网络空间资产探测关键技术研究
  9. 《上海市工业互联网创新发展专项支持实施细则》政策解读
  10. 在股票技术指标里,EMA和SMA 的区别