14
2
Task
Given two lists of characters, output their Cartesian product, i.e. the list of pairings of each letter from the first list with each letter from the second list.
Example
"123456"
and "abcd"
give:
[["1","a"],["1","b"],["1","c"],["1","d"],["2","a"],["2","b"],["2","c"],["2","d"],["3","a"],["3","b"],["3","c"],["3","d"],["4","a"],["4","b"],["4","c"],["4","d"],["5","a"],["5","b"],["5","c"],["5","d"],["6","a"],["6","b"],["6","c"],["6","d"]]
Input
Two lists of characters or strings. The characters used will be alphanumeric a-z, A-Z, 0-9
and a character can occur both multiple times and in both inputs at the same time.
Output
The Cartesian product of the input lists. That is, a list of each possible ordered pair of a character from the first list and a character from the second list. Each pair is a list or string or similar of two characters, or of two length-one strings. The output's length will be equal to the product of the lengths of the inputs.
The pairs must be listed in order; first listing the first character of the first list with the first of the second list, followed by all the pairings of the first character of the first list. The last pair consists of the last character of the first list together with the last character of the second list.
The output must be a flat list of pairs; not a 2D matrix where pairs are grouped by their first or second element.
Test cases
inputs output
"123456", "abcd" [["1","a"],["1","b"],["1","c"],["1","d"],["2","a"],["2","b"],["2","c"],["2","d"],["3","a"],["3","b"],["3","c"],["3","d"],["4","a"],["4","b"],["4","c"],["4","d"],["5","a"],["5","b"],["5","c"],["5","d"],["6","a"],["6","b"],["6","c"],["6","d"]]
"abc", "123" [["a","1"],["a","2"],["a","3"],["b","1"],["b","2"],["b","3"],["c","1"],["c","2"],["c","3"]]
"aa", "aba" [["a","a"],["a","b"],["a","a"],["a","a"],["a","b"],["a","a"]]
@Adám Changed. I'm having trouble though wording that repeated characters in an input string can and should cause repeated pairs in the output (assuming that's how interpret it). – xnor – 2017-06-08T00:25:56.327
@xnor maybe easier if the order of pairs is fixed? – Adám – 2017-06-08T00:28:18.923
Why does the title say "list" yet the body say "list of characters"? – Leaky Nun – 2017-06-08T07:56:06.720
Just to be sure: is
["1a", "1b", "1c", "2a", "2b", "2c", "3a", "3b", "3c"]
a valid output format? – Shaggy – 2017-06-08T16:22:37.167wow. lots of amazing answers. what are the criteria for chosing an accepted answer? And should I give my own answer on es5 (the code that inspired the question in the first place?) – alexandros84 – 2017-06-09T03:22:42.347
1
You tagged this as
– Shaggy – 2017-06-09T10:52:56.703code-golf
therefore shortest answer wins. In the event of a tie, the first answer to reach that score is usually the winner (currently this one). Give it another few days, at least, before accepting an answer, though, if at all. And see here for guidelines on answering your own question.@Adám ty for editing. – alexandros84 – 2017-06-11T03:17:16.790
@Adám I assume taking the input as boxed in J allowed? – Jonah – 2017-09-22T05:43:28.957
@Jonah I'd think so. That's natural for J. – Adám – 2017-09-23T20:19:58.483
@Adám, Sorry I thought you were the OP and not just the editor. But thanks. – Jonah – 2017-09-23T20:40:49.977