0

我有一个需要调用的制裁 api,传入一串值。这些值的构造如下:

string searchString = string.Join(" ", myList.ToArray());
// remove any numbers and return complete words
MatcCollection strMatch = Regex.Matches(searchString, @"[^\W\d]+");

var values = strMatch.Cast<Group>().Select(g => g.Value).ToArray();

var combinations = values.Permutations();

现在,我有了我需要的数组,我在下面调用 Permutations 方法:

public static IEnumerable<IEnumerable<T>> Permutations<T>(this IEnumerable<T> source)
    {
        if (source == null)
            throw new ArgumentException("source");
        return permutations(source.ToArray());
    }

排列方法是:

private static IEnumerable<IEnumerable<T>> permutations<T>(IEnumerable<T> source)
    {
        var c = source.Count();
        if (c == 1)
            yield return source;
        else
            for (int i = 0; i < c; i++)
                foreach (var p in permutations(source.Take(i).Concat(source.Skip(i + 1))))
                    yield return source.Skip(i).Take(1).Concat(p);
    }

对于 7 个项目的示例列表 {一、二、三、四、五、六、七},此代码返回多个长度为 7 个元素的列表。

我需要创建的是以下内容:

第一次迭代:

返回结果=一

第二次迭代返回结果 = 一 + ' ' + 二

等等等等

我从 SO 上的帖子中获得了上面的示例代码,所以不知道如何正确更改它以获得我需要的东西。

4

1 回答 1

2

那么我是否正确,您不仅想要 7 个项目的所有排列,而且还想要枚举它们的任何子集(类似于所有组合)?

我想获得这种行为的最简单方法是在方法中添加某种长度参数permutations

private static IEnumerable<IEnumerable<T>> permutations<T>(IEnumerable<T> source, int length)
{
    var c = source.Count();
    if (length == 1 || c == 1)
        foreach(var x in source)
            yield return new T[] { x };
    else
        for (int i = 0; i < c; i++)
            foreach (var p in permutations(source.Take(i).Concat(source.Skip(i + 1)), length - 1))
                yield return source.Skip(i).Take(1).Concat(p);
}

然后使用从 1 到 n 的参数调用此方法:

public static IEnumerable<IEnumerable<T>> Permutations<T>(this IEnumerable<T> source)
{
    if (source == null)
        throw new ArgumentException("source");
    var src = source.ToArray();
    for (int i = 1; i <= src.Length; i++)
        foreach (var result in permutations(src, i))
            yield return result;
}

希望我没有写错别字...

于 2013-09-12T11:05:18.837 回答