ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: luoyin268

四组数据中选五个,VBA如何实现

[复制链接]

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:17 | 显示全部楼层
未去除重复时有结果972个。
=3^4*3*4=972

去除重复后只有648个结果
=3^4*(3-1)*4=648
  1. Sub test2()
  2.     tms = Timer
  3.     arr = Range("a1").CurrentRegion
  4.     m = UBound(arr): n = UBound(arr, 2)
  5.     ReDim brr(1 To m ^ n * (m - 1) * n, n + 1): k = 0
  6.     Dim i1%, i2%, i3%, i4%
  7.     For i1 = 1 To m
  8.     For i2 = 1 To m
  9.     For i3 = 1 To m
  10.     For i4 = 1 To m
  11.     For i5 = 1 To m
  12.     For j5 = 1 To n
  13.         If i5 = i1 And j5 = 1 Then GoTo Nxt
  14.         If i5 = i2 And j5 = 2 Then GoTo Nxt
  15.         If i5 = i3 And j5 = 3 Then GoTo Nxt
  16.         If i5 = i4 And j5 = 4 Then GoTo Nxt
  17.         k = k + 1
  18.         brr(k, 0) = arr(i1, 1) & "," & arr(i2, 2) & "," & arr(i3, 3) & "," & arr(i4, 4) & "," & arr(i5, j5)
  19.         brr(k, 1) = arr(i1, 1)
  20.         brr(k, 2) = arr(i2, 2)
  21.         brr(k, 3) = arr(i3, 3)
  22.         brr(k, 4) = arr(i4, 4)
  23.         brr(k, 5) = arr(i5, j5)
  24. Nxt:
  25.     Next j5, i5, i4, i3, i2, i1
  26.     [a1].Offset(, n + 2).Resize(k, n + 2) = brr
  27.     MsgBox k & vbCr & Format(Timer - tms, "0.000s")
  28. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:19 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
用【香川组合】的递归代码稍微修改了一下:
  1. Dim sj, jg(), m%, n%, k
  2. Sub 香川组合递归2()
  3.     tms = Timer
  4.     sj = [a1].CurrentRegion: m = UBound(sj): n = UBound(sj, 2): Amn = m ^ n * (m - 1) * n
  5.     If Amn > 65536 Then Exit Sub Else ReDim jg(Amn, n + 1): k = 0
  6.     Call dgMn("", 0)
  7.     [a1].Offset(, n + 2).CurrentRegion = "": [a1].Offset(, n + 2).Resize(Amn, n + 2) = jg
  8.     MsgBox k & vbCr & Format(Timer - tms, "0.000s")
  9. End Sub
  10. Sub dgMn(s$, t%)
  11.     If t = n Then
  12.         p = Split(s, ",")
  13.         l = 0
  14.         For i = 1 To m
  15.             For j = 1 To n
  16.                 If i <> Val(p(j)) Then
  17.                     For jj = 1 To n
  18.                         jg(k + l, jj) = sj(p(jj), jj)
  19.                         jg(k + l, 0) = jg(k + l, 0) & "," & jg(k + l, jj)
  20.                     Next
  21.                     jg(k + l, n + 1) = sj(i, j)
  22.                     jg(k + l, 0) = Mid(jg(k + l, 0), 2) & "," & jg(k + l, n + 1)
  23.                     l = l + 1
  24.                 End If
  25.             Next
  26.         Next
  27.         k = k + l: Exit Sub
  28.     End If
  29.     For j = 1 To m
  30.         Call dgMn(s & "," & j, t + 1)
  31.     Next j
  32. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-11-13 21:34 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:35 | 显示全部楼层
换一种递归代码……可是效率并没有提高,因为重复部分没有被有效利用。
  1. Dim sj, jg(), m%, n%, k
  2. Sub 香川组合递归4()
  3.     tms = Timer
  4.     sj = [a1].CurrentRegion: m = UBound(sj): n = UBound(sj, 2): Amn = m ^ n * (m - 1) * n
  5.     If Amn > 65536 Then Exit Sub Else ReDim jg(Amn, n + 1): k = 0
  6.     Call dgM("", 0)
  7.     [a1].Offset(, n + 2).CurrentRegion = "": [a1].Offset(, n + 2).Resize(Amn, n + 2) = jg
  8.     MsgBox k & vbCr & Format(Timer - tms, "0.000s")
  9. End Sub
  10. Sub dgM(s$, t%)
  11.     If t = n + 1 Then
  12.         p = Split(s, ",")
  13.         For j = 1 To n
  14.             jg(k, j) = sj(p(j), j)
  15.             jg(k, 0) = jg(k, 0) & "," & jg(k, j)
  16.         Next
  17.         q = Split(p(n + 1), ";")
  18.         jg(k, n + 1) = sj(q(0), q(1))
  19.         jg(k, 0) = Mid(jg(k, 0), 2) & "," & jg(k, n + 1)
  20.         k = k + 1
  21.         Exit Sub
  22.     End If
  23.     For i = 1 To m
  24.         If t = n Then
  25.             For j = 1 To n
  26.                 If i <> Val(Split(s, ",")(j)) Then Call dgM(s & "," & i & ";" & j, t + 1)
  27.             Next
  28.         Else
  29.             Call dgM(s & "," & i, t + 1)
  30.         End If
  31.     Next
  32. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:37 | 显示全部楼层
4种代码的附件。

组合.rar

22.74 KB, 下载次数: 7

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-11-13 21:40 | 显示全部楼层
还有相同 的,还在请老大改改!!!如表所示

555.rar

13.1 KB, 下载次数: 3

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:43 | 显示全部楼层
luoyin268 发表于 2012-11-13 21:34
怎么还有648组数据!我理论算了才324种啊!!!!

楼主你这个错误结果就别提什么理论了吧。

正确的计算过程和结果,我已经在11楼写出来了。


现在,把你的计算过程贴出来,帮你挑挑错在哪里。



TA的精华主题

TA的得分主题

 楼主| 发表于 2012-11-13 21:47 | 显示全部楼层
还有相同的,如表,请老大再帮我改该!!

555.rar

13.1 KB, 下载次数: 3

TA的精华主题

TA的得分主题

发表于 2012-11-13 21:47 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
理论计算是:

=combin(3,1)*combin(3,1)*combin(3,1)*combin(3,1)*combin(3*4-4,1)
=3*3*3*3*(3-1)*4
=3^4*(3-1)*4
=81*8
=648


或者,如果m行n列,取n+1个值的组合时,通用计算公式:
=m^n*(m-1)*n

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-11-13 21:50 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
每组数据,不能重复!如表
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-28 12:13 , Processed in 0.047199 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表