GetPermutations
GetPermutations
Source
public static IEnumerable<IEnumerable<T>> GetPermutations<T>(this IEnumerable<T> items) {
if (items.Count() > 1) {
return items.SelectMany(item => GetPermutations(items.Where(i => !i.Equals(item))),
(item, permutation) => new[] { item }.Concat(permutation));
} else {
return new[] { items };
}
}
Example
var l = new List<int> { 1, 2, 3, 4 };
foreach (var item in l.GetPermutations()) {
foreach (var value in item) {
Console.Write(value);
Console.Write(" ");
}
Console.WriteLine();
}
Author: Fons Sonnemans
Submitted on: 3 sep. 2013
Language: C#
Type: System.Collection.Generic.IEnumerable<T>
Views: 6153