我有一组字符串,并希望找到所有可能的字符串组合并将它们添加到一个列表中。我想得到一个每个字符串组合的列表,不包括空集。
我已经用嵌套的for循环创建了一个可以精确实现这一点的解决方案。然而,我希望更加优雅地做到这一点,最好是使用LINQ,但是因为我还是新手,所以在使用它方面并不熟练。
这个解决方案应该有2^n - 1个组合列表,其中n是原始集合的基数。下面是我要找的正确示例:
有人能给我展示一个更优雅的解决方案吗?我已经看到过类似的LINQ解决方案,它们创建笛卡尔对和带有阈值的列表,但我还没有能够调整它们以适应我的需求。
我已经用嵌套的for循环创建了一个可以精确实现这一点的解决方案。然而,我希望更加优雅地做到这一点,最好是使用LINQ,但是因为我还是新手,所以在使用它方面并不熟练。
这个解决方案应该有2^n - 1个组合列表,其中n是原始集合的基数。下面是我要找的正确示例:
set = {a, b, c}
completedListOfCombinations =
{
{a},
{b},
{a, b},
{c},
{a, c},
{b, c},
{a, b, c}
}
这是我基于https://dev59.com/enA75IYBdhLWcg3wZ4Fr#3319652的帮助,制作的工作中的解决方案,虽然简单但不够美观。
List<string> myStrings = new List<string> { "a", "b", "c" };
var allCombos = new List<List<string>>();
for (int i = 0; i < myStrings.Count; i++)
{
int subsetCount = allCombos.Count;
var m = new List<string>();
m.Add(myStrings[i]);
allCombos.Add(m);
for (int j = 0; j < subsetCount; j++)
{
string[] subset = new string[allCombos.ElementAt(j).Count + 1];
allCombos[j].CopyTo(subset, 0);
subset[subset.Length - 1] = myStrings[i];
allCombos.Add(subset.ToList());
}
}
有人能给我展示一个更优雅的解决方案吗?我已经看到过类似的LINQ解决方案,它们创建笛卡尔对和带有阈值的列表,但我还没有能够调整它们以适应我的需求。