C#LINQ组合:没有空集的集合的所有组合

前端之家收集整理的这篇文章主要介绍了C#LINQ组合:没有空集的集合的所有组合前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一组字符串,我想找到所有可能的字符串组合并将它们添加到列表中.我想最终得到一个列表,列出每个字符串组合,减去空集.

我已经创建了一个解决方案,它完全使用嵌套的for循环.但是我想更优雅地做到这一点,最好是使用LINQ,而我对它并不是那么精通,因为我还是很陌生.

解决方案应该有2 ^ n – 1个组合列表,其中n是原始集合的基数.以下是我正在寻找的正确例子:

  1. set = {a,b,c}
  2.  
  3. completedListOfCombinations =
  4. {
  5. {a},{b},{a,b},{c},c},{b,c}
  6. }

这是我的工作,基本但丑陋的解决方案,我在https://stackoverflow.com/a/3319652/3371287的帮助下制作

  1. List<string> myStrings = new List<string> { "a","b","c" };
  2.  
  3. var allCombos = new List<List<string>>();
  4.  
  5. for (int i = 0; i < myStrings.Count; i++)
  6. {
  7. int subsetCount = allCombos.Count;
  8. var m = new List<string>();
  9. m.Add(myStrings[i]);
  10. allCombos.Add(m);
  11.  
  12. for (int j = 0; j < subsetCount; j++)
  13. {
  14. string[] subset = new string[allCombos.ElementAt(j).Count + 1];
  15. allCombos[j].CopyTo(subset,0);
  16. subset[subset.Length - 1] = myStrings[i];
  17. allCombos.Add(subset.ToList());
  18. }
  19.  
  20. }

有人能告诉我一个更优雅的解决方案吗?我已经看到了类似的LINQ解决方案,它们创建了具有阈值的笛卡尔对和列表,但我无法将它们调整到我需要的位置.

解决方法

假设列表中的所有值都是唯一的:
  1. List <String> list = new List<String> { "a","c" };
  2.  
  3. var result = Enumerable
  4. .Range(1,(1 << list.Count) - 1)
  5. .Select(index => list.Where((item,idx) => ((1 << idx) & index) != 0).ToList());

要打印出来:

  1. Console.WriteLine(String
  2. .Join(Environment.NewLine,result
  3. .Select(line => String.Join(",",line))));

结果是

  1. a
  2. b
  3. a,b
  4. c
  5. a,c
  6. b,c
  7. a,c

猜你在找的C&C++相关文章