Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Excel: VBA Routine To List Table Of Combinations

Posted on 2011-02-22
9
Medium Priority
?
686 Views
Last Modified: 2012-05-11
Given the following input data (cells L8:Q8): 1, 1, 2, 1, 5, 3
I would like a VBA routine to list all combinations in a table beginning at cell S8, as follows:
1      1      1      1      1      1
1      1      1      1      1      2
1      1      1      1      1      3
1      1      1      1      1      1,2
1      1      1      1      1      1,3
1      1      1      1      1      2,3
1      1      1      1      1      1,2,3
1      1      2      1      1      1
1      1      2      1      1      2
1      1      2      1      1      3
1      1      2      1      1      1,2
1      1      2      1      1      1,3
1      1      2      1      1      2,3
1      1      2      1      1      1,2,3
...

Please advise?

Best wishes,

John
0
Comment
Question by:jfdinneen
  • 4
  • 2
  • 2
  • +1
9 Comments
 
LVL 20

Expert Comment

by:Ardhendu Sarangi
ID: 34954222
can you attach a file? your question doesn't seem too clear as to what do you want in Column S.
0
 
LVL 24

Expert Comment

by:StephenJR
ID: 34954278
Can you elaborate, don't really follow what you are doing?
0
 

Author Comment

by:jfdinneen
ID: 34954663
As requested...

Best wishes,

John
 EE-Q-26839515.xlsm
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 20

Expert Comment

by:Ardhendu Sarangi
ID: 34954690
Hi,

I am still not getting it... whats the difference between Input, Listing and Combinations? Can you please explain once more? thanks!
0
 

Author Comment

by:jfdinneen
ID: 34954769
For example, under heading 'F', the Input is 3 objects in bin 'F', the Listing is simply the nominal tags of those same objects (1,2,3), and the Combination is the power set (minus empty set) of the listed objects iterated across all power sets of the othe bins ({1} {2} {3} {1,2} {1,3} {2,3} {1,2,3}).

Best wishes,

John
0
 
LVL 4

Accepted Solution

by:
rowanscott earned 2000 total points
ID: 34969560
Hi John

I think this is what you mean (see attached file).  If you copy and paste the code into another workbook you will also need to copy the c_Bin class module.

It took me a while to figure out iterating through the possibilities but it was a good puzzle. Changing the quantity of bins shouldn't be a problem though. It should cope with that fine.

If its not quite what you are after let me know. Or if you want help understanding the class module.

Best regards

Rowan
Demo.xlsm
0
 

Author Closing Comment

by:jfdinneen
ID: 34970706
Thanks Rowan.

Excellent solution. I have a related problem that I will post later today which I would like you to review.

Best wishes,

John
0
 

Author Comment

by:jfdinneen
ID: 34971357
Rowan,

Is it possible to have the listing as per my original question? Also, the related problem is posted as Q26845042.

Best wishes,

John
0
 
LVL 4

Expert Comment

by:rowanscott
ID: 34974152
You'll have to explain that a bit?
0

Featured Post

[Webinar] Cloud Security

In this webinar you will learn:

-Why existing firewall and DMZ architectures are not suited for securing cloud applications
-How to make your enterprise “Cloud Ready”, and fix your aging DMZ architecture
-How to transform your enterprise and become a Cloud Enabler

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In Part II of this series, I will discuss how to identify all open instances of Excel and enumerate the workbooks, spreadsheets, and named ranges within each of those instances.
Windows Explorer lets you open cabinet (cab) files like any other folder. In VBA you can easily handle normal files and folders, but opening and indeed creating cabinet files takes a lot more - and that's you'll find here.
This Micro Tutorial will demonstrate on a Mac how to change the sort order for chart legend values and decrpyt the intimidating chart menu.
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

916 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question