cartesian_product.sf 599 B

12345678910111213141516171819202122232425262728293031323334353637
  1. #!/usr/bin/ruby
  2. # Cartesian product of an arbitrary number of arrays.
  3. func cartesian_product(*arr) {
  4. var c = []
  5. var r = []
  6. func {
  7. if (c.len < arr.len) {
  8. for item in (arr[c.len]) {
  9. c.push(item)
  10. __FUNC__()
  11. c.pop
  12. }
  13. }
  14. else {
  15. r.push([c...])
  16. }
  17. }()
  18. return r
  19. }
  20. cartesian_product(['a', 'b'], ['c', 'd'], ['e', 'f']).each{ .say }
  21. __END__
  22. ["a", "c", "e"]
  23. ["a", "c", "f"]
  24. ["a", "d", "e"]
  25. ["a", "d", "f"]
  26. ["b", "c", "e"]
  27. ["b", "c", "f"]
  28. ["b", "d", "e"]
  29. ["b", "d", "f"]