Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
12
返回列表 发新帖
楼主: sailorgo

[已解决]12个数随机抽取6个数进行求和,如何穷尽?

[复制链接]
 楼主| 发表于 2016-11-29 07:44 | 显示全部楼层
自己再顶一下,谢谢各位!
回复

使用道具 举报

发表于 2016-11-29 08:20 | 显示全部楼层
sailorgo 发表于 2016-11-28 14:52
各位大咖:
      有N行数据,共12列,对这12列数据选出6列进行组合,对各组合进行求和
       例如:

最大有多少行?
如果有几千几万、甚至几十万行,那么计算和输出都是很大的负担。

如果小于250行,可以把行列转置,取1-12行中的6行进行组合求和,结果输出在下面的924行中。


回复

使用道具 举报

发表于 2016-11-29 09:58 | 显示全部楼层    本楼为最佳答案   
本帖最后由 香川群子 于 2016-11-29 12:40 编辑

按列输出的代码:

  1. Dim sj, jg(), k&, l&, m&, n&
  2. Sub Combin_1()
  3.     tms = Timer
  4.     sj = [a1].CurrentRegion: l = UBound(sj)
  5.     m = 12: n = 6: k = WorksheetFunction.Combin(m, n)
  6.     ReDim jg(1 To l, k)
  7.    
  8.     k = 0: Call dgZH(0, 1)
  9.     MsgBox Format(Timer - tms, "0.000s")
  10.     [o1].CurrentRegion = "": [o1].Resize(l, k) = jg
  11. End Sub
  12. Sub dgZH(j1&, t&)
  13.     Dim i&, j&
  14.     For j = j1 + 1 To 6 + t 'm - n + t
  15.         For i = 1 To l
  16.             jg(i, k) = jg(i, k) + sj(i, j)
  17.         Next
  18.         If t < n Then
  19.             Call dgZH(j, t + 1)
  20.         Else
  21.             k = k + 1
  22.             For i = 1 To l
  23.                 jg(i, k) = jg(i, k - 1)
  24.             Next
  25.         End If
  26.         For i = 1 To l
  27.             jg(i, k) = jg(i, k) - sj(i, j)
  28.         Next
  29.     Next
  30. End Sub
复制代码


注意输出语句要改一下:
[o1].CurrentRegion = "": [o1].Resize(l, k) = jg

我测试时用了数字10,只能输出10列。

评分

参与人数 1 +20 金币 +20 收起 理由
望帝春心 + 20 + 20 来学习~谢谢香川老师!

查看全部评分

回复

使用道具 举报

 楼主| 发表于 2016-11-29 12:24 | 显示全部楼层

谢谢香川老师!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-2 08:24 , Processed in 0.258518 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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