标题:求大神翻译下,这段代码是如何生成不重复的26个英文字母?
只看楼主
牛蛙点点
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2020-7-9
结帖率:0
已结贴  问题点数:20 回复次数:3 
求大神翻译下,这段代码是如何生成不重复的26个英文字母?
搞不明白for j = 0 后面是怎么样的

Private Sub Command1_Click()
Dim a(25), i As Integer, j As Integer, s As String, length As Integer, c As String
Dim t
Randomize
For i = 0 To 25
a(i) = Chr(Int(Rnd() * 26 + 65))
For j = 0 To i - 1
If a(i) = a(j) Then
i = i - 1
Exit For
End If
Next j
Next i

搜索更多相关主题的帖子: For 翻译 英文字母 Integer 代码 
2020-07-09 16:13
cwa9958
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:67
帖 子:247
专家分:1228
注 册:2006-6-25
得分:10 
就是刚生成的a(i)与以前生成的字符去校对,如果有相同的,就 重新生成一个,为什么会i=i-1,是因为next语句会自动+1的,所以先-1。在j循环里正常执行完了,是没有i=i-1的,这样next i后,才生成下一个字母。
2020-07-10 08:39
cwa9958
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:67
帖 子:247
专家分:1228
注 册:2006-6-25
得分:0 
给一个简单的生成不重复26个字母的代码:

程序代码:
Private Sub Command2_Click()
    Dim a(25) As String, i As Integer, j As Integer, st As String
    st = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
    For i = 25 To 0 Step -1
        j = Rnd() * i + 1
        a(i) = Mid(st, j, 1)
        st = Replace(st, a(i), "")
        Print a(i);
    Next
    Print
End Sub
2020-07-10 08:57
yangying817
Rank: 2
等 级:论坛游民
帖 子:4
专家分:10
注 册:2020-7-10
得分:10 
新生成的和已经生成的一一对比,如果有,就再生成一个,如果没有,这个就生成了
2020-07-10 11:49



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-502457-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.813819 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved