您的位置:首页 > 其它

递归实现数字排列组合

2007-10-30 16:33 531 查看
参考彭希仁的递归算法

Sub macro1()
Dim arr() As String
getall 9, 3, "", arr
Debug.Print Join(arr, ",")
End Sub
Sub getall(ByVal m As Byte, ByVal n As Byte, ByRef a As String, ByRef arr() As String, Optional ByRef count As Long)
If Len(a) = n Then
count = count + 1
ReDim Preserve arr(1 To count)
arr(count) = a
Exit Sub
End If
For i = 0 To m 'Val(Right(a, 1)) To m
If InStr(a, i) = 0 Then getall m, n, a & i, arr, count
Next i
End Sub
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: