Generate All Partitions of a List
The new functions FoldPair and FoldPairList allow mapping simultaneously an output function and a state-update function.
Take a length-5 list to be partitioned.
In[1]:=
data:image/s3,"s3://crabby-images/791a3/791a31164ce6e09ee6df78e373b94601e6c77fb2" alt="Click for copyable input"
list = {a, b, c, d, e};
Use FoldPairList together with TakeDrop to generate a partition of the following lengths.
In[2]:=
data:image/s3,"s3://crabby-images/f65d7/f65d7537bc1e5f5502f655769a5495ed7aec82d9" alt="Click for copyable input"
lengths = {2, 2, 1};
FoldPairList[TakeDrop, list, lengths]
Out[2]=
data:image/s3,"s3://crabby-images/2ba5d/2ba5ddd7c236da481f584bde5dec414e677535fb" alt=""
To construct all partitions, find all possible decompositions of the number 5.
In[3]:=
data:image/s3,"s3://crabby-images/d5b7f/d5b7fc257f14bf566be778b31a73af53483c5954" alt="Click for copyable input"
lengthsAll = Flatten[Permutations /@ IntegerPartitions[5], 1]
Out[3]=
data:image/s3,"s3://crabby-images/4dab7/4dab7f22c6c293dd8447a76af0206fcf4959e774" alt=""
In[4]:=
data:image/s3,"s3://crabby-images/0ee37/0ee379f75ce764a64fc3f3203e1f5c3431da885c" alt="Click for copyable input"
FoldPairList[TakeDrop, list, #] & /@ lengthsAll // Column
Out[4]=
data:image/s3,"s3://crabby-images/ccd49/ccd494ad819abb3438c4a2c7ef22947a9939b2bb" alt=""