0

I have two arrays:

var array1: [String] = ["l1", "m2", "r3"]
var array2: [String] = ["l4", "m5", "r6"]

How can I combine them to form an array that looks like

var combinations: [[String]] = [
["l1", "m2", "r3"], ["l1", "m5", "r3"], ["l1", "m5", "r6"], ["l1", "m2", "r6"],
["l4", "m2", "r3"], ["l4", "m5", "r3"], ["l4", "m5", "r6"], ["l4", "m2", "r6"]
]

EDIT 1: In case if you have more than 2 arrays

let arrays: [[String]] = [array1, array2, moreArrays]
var combinations: [[String]] = []

let arraysLen: Int = arrays.count
let arrLen: Int = arrays[0].count
let numCombinations: Int = Int(pow(Double(arraysLen), Double(arrLen)))

for i in (0 ..< numCombinations) {
  var combination: [String] = []
  for j in (0 ..< arrLen) {
    let arrIndex: Int = i / Int(pow(Double(arraysLen), Double(j))) % arraysLen
    let elIndex: Int = arrLen - j - 1
    combination.insert(arrays[arrIndex][elIndex], at: 0)
  }
  combinations.append(combination)
}
Ivan
  • 13
  • 2

2 Answers2

1

If you want to get possible combinations of exactly two arrays, you can use a simple bit trick:

var array1: [String] = ["l1", "m2", "r3"]
var array2: [String] = ["l4", "m5", "r6"]

guard array1.count == array2.count else {
    fatalError("Array must be of the same lenght")
}

let numCombinations = 1 << array1.count
let combinations: [[String]] = (0..<numCombinations).map { (index: Int) in
    return Array((0..<array1.count).map { (elementIndex: Int) in
        // every bit decides which array to choose
        let chooseArray1 = (index & (1 << elementIndex)) == 0
        return chooseArray1 ? array1[elementIndex] : array2[elementIndex]
    })
}
print(combinations) // [["l1", "m2", "r3"], ["l4", "m2", "r3"], ["l1", "m5", "r3"], ["l4", "m5", "r3"], ["l1", "m2", "r6"], ["l4", "m2", "r6"], ["l1", "m5", "r6"], ["l4", "m5", "r6"]]
Sulthan
  • 128,090
  • 22
  • 218
  • 270
1

If both array counts are same, iterate both arrays and swap objects in each iteration from the original array and append to the result.

var combinations: [[String]] = []
if array1.count == array2.count {
    combinations.append(array1)
    combinations.append(array2)
    for i in 0..<array1.count {
        var arr1 = array1
        var arr2 = array2
        (arr1[i], arr2[i]) = (arr2[i], arr1[i])
        combinations.append(arr1)
        combinations.append(arr2)
    }
    print(combinations)
}

[["l1", "m2", "r3"], ["l4", "m5", "r6"], ["l4", "m2", "r3"],["l1", "m5", "r6"],
["l1", "m5", "r3"], ["l4", "m2", "r6"], ["l1", "m2", "r6"], ["l4", "m5", "r3"]]

RajeshKumar R
  • 15,445
  • 2
  • 38
  • 70