各位网友, 在EXCEL VBA中 1给一个生成100个随机整数的代码(1到1000的) 2给一个生成100个不等的随机整数

请问必须用到Randomize吗,用到与用不到结果有何区别谢谢... 请问必须用到Randomize吗,用到与用不到结果有何区别
谢谢
展开
 我来答
syht2000
高粉答主

2011-03-29 · 关注我不会让你失望
知道大有可为答主
回答量:3万
采纳率:79%
帮助的人:1.5亿
展开全部
Randomize必须要用,它是用来初始化随机种子的(基本上所有语言中都有类似语句),不用这个你每运行这个程序,得到的随机数结果就是会一样的,比如第一次10,第二次8等等。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
太极健1969
2011-03-29 · TA获得超过9034个赞
知道大有可为答主
回答量:8668
采纳率:69%
帮助的人:3736万
展开全部
Sub aa()
Dim arr
Dim x&
ReDim arr(1 To 100)
For x = 1 To 100
arr(x) = Int(Rnd * 99 + 1)
Next
Range("A1").Resize(UBound(arr)) = Application.Transpose(arr)
End Sub
生成1到100的随机整数。有重复。
更多追问追答
追问
Range("A1").Resize(UBound(arr)) = Application.Transpose(arr)
这个代码是何意,上述代码中怎么未显示出用到Randomize
追答
那句代码的意思是从A1开始写入,行数与数组行数一样,因为这是一维数组,要转置写入数组值
因你是生成1到100的随机整数,这里是指定生成100个随机1到100的整数。你可以把这代码改成
Range("A1").Resize(100) = Application.Transpose(arr)
因代码中我们可以改为生成200个或者其他任意个,就要修改那些所有的100,而用了ubound(arr)这句,就不用修改,只需要修改上面的两个100即可,如果再设置一个变量,那就只需要修改一个就行了如:要几个数,就修改一下以下代码中的i=100,把100改成你要的个数即可
Sub aa()
Dim arr
Dim x&,i&
i=100
ReDim arr(1 To i)
For x = 1 To i
arr(x) = Int(Rnd * (i-1) + 1)
Next
Range("A1").Resize(i) = Application.Transpose(arr)
End Sub

另:Randomize是让随机数初始化指定基数的,不是一定要用的,看情况用,具体用法请参考帮助
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式