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

C#LINQ组合:没有空集的集合的所有组合,第1张

概述我有一组字符串,我想找到所有可能的字符串组合并将它们添加到列表中.我想最终得到一个列表,列出每个字符串组合,减去空集. 我已经创建了一个解决方案,它完全使用嵌套的for循环.但是我想更优雅地做到这一点,最好是使用LINQ,而我对它并不是那么精通,因为我还是很陌生. 解决方案应该有2 ^ n – 1个组合列表,其中n是原始集合的基数.以下是我正在寻找的正确例子: set = {a, b, c}c 我有一组字符串,我想找到所有可能的字符串组合并将它们添加到列表中.我想最终得到一个列表,列出每个字符串组合,减去空集.

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

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

set = {a,b,c}completedlistofCombinations = {    {a},{b},{a,b},{c},c},{b,c}}

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

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解决方案,它们创建了具有阈值的笛卡尔对和列表,但我无法将它们调整到我需要的位置.

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

要打印出来:

Console.Writeline(String  .Join(Environment.Newline,result     .Select(line => String.Join(",",line))));

结果是

aba,bca,cb,ca,c
总结

以上是内存溢出为你收集整理的C#LINQ组合:没有空集的集合的所有组合全部内容,希望文章能够帮你解决C#LINQ组合:没有空集的集合的所有组合所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1242597.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存