本帖最后由 香川群子 于 2014-11-11 17:28 编辑
代码:- Dim sj, sj2, jg2$(), k&, l&, m&, n&, n2&, w1$, w2$, cnt&
- Sub MultiCombinPermut() 'by kagawa
- Dim cc, i&, m1, s$, t, tms#
- 'Combin(5,0-5)=10000;01000;00100;00010;00001;10000
- 'Permut(5,0-5)=10000;11000;11100;11110;11111;11111
-
- m = [a3].End(4).Row - 3
- w1 = [a2]: w2 = [b2]: n2 = Len(w2) + 1
- [c:d] = "": sj = [a4].Resize(m, 3)
-
- n = 1: cc = 1: t = 1
- Cells(4, 3).Activate
- For i = 2 To m
- If sj(i, 2) Then
- If sj(i, 2) = t Then
- m1 = m - n + 1: n = i - n
- Else
- s = s & vbCr & "Combin(1,1)=1"
- ActiveCell = "Combin(1,1)=1"
- ActiveCell.Offset(1).Activate
- m1 = m - n: n = i - n - 1: t = sj(i, 2)
- End If
- k = WorksheetFunction.Combin(m1, n): cc = TM2(cc, k) '此处调用长数位乘法自定义函数
- s = s & vbCr & "Combin(" & m1 & "," & n & ")=" & k
- ActiveCell = "Combin(" & m1 & "," & n & ")=" & k
- n = i
- Cells(i + 3, 3).Activate
- End If
- Next
- s = s & vbCr & "Combin(" & m - n + 1 & "," & i - n & ")=1"
- ActiveCell = "Combin(" & m - n + 1 & "," & i - n & ")=1"
- [c3] = "k=" & cc: MsgBox "k=" & Format(cc, "#,##0") & s
-
- l = Val(InputBox("Output Count Lines:", "l=", IIf(cc > Rows.Count, Rows.Count, cc)))
- If l = 0 Then Exit Sub
-
- tms = Timer: [c2] = "Output: " & l: ReDim jg2$(l, 0)
- ReDim sj2(1 To m) As Boolean
-
- k = 0: cnt = 0: Call dgZH4("", 0, 1)
- [d1].Resize(k) = jg2
- [c1:d1].EntireColumn.AutoFit
- MsgBox Format(Timer - tms, "0.000s ") & k & "/" & cnt
- End Sub
- Sub dgZH4(s$, i&, t&)
- Dim ii&, j&, s2$, t2&
- If k = l Then Exit Sub
- cnt = cnt + 1
- For j = i + 1 To m
- If Not sj2(j) Then
- If t < n Then
- sj2(j) = True
- If sj(t + 1, 2) = "" Then
- If sj(t, 2) Then sj(sj(t, 2) + 1, 3) = j - 1
- Call dgZH4(s & w2 & sj(j, 1), j, t + 1)
- Else
- Call dgZH4(s & w2 & sj(j, 1) & w1, Val(sj(sj(t + 1, 2), 3)), t + 1)
- End If
- sj2(j) = False
- Else
- For ii = sj(sj(t, 2), 3) + 1 To m
- If Not sj2(ii) Then s2 = s2 & w2 & sj(ii, 1): t2 = t2 + 1
- Next
- If t + t2 = m + 1 Then
- If w1 = "" Then '增加当组间符设置为空时,不输出最后一组。
- jg2(k, 0) = Mid(s, n2)
- Else
- jg2(k, 0) = Replace(Mid(s & s2, n2), w1 & w2, w1)
- End If
- k = k + 1
- End If
- Exit Sub
- End If
- End If
- Next
- End Sub
复制代码 |