当试图解决这个问题时
一组九个元素中有多少个七元素子集(不可重复)?
我试过了
IEnumerable<string> NineSet =new string[] {"a","b","c","d","e","f","g","h","i"};
var SevenSet =
from first in NineSet
from second in NineSet
where first.CompareTo(second)< 0 && first.Count() + second.Count()==7
select new { first, second };阻止我尝试使用first.Count()和second.Count()的问题是什么?我没有检查这是否是解决这个问题的最佳办法。
发布于 2009-10-19 11:04:22
第一和第二是字符串,所以您将计算它们的字符(这是编译的,但智力隐藏它)。
你在找像NineSet.Count(first.Equals)这样的东西
发布于 2009-10-19 11:10:09
如前所述,你写下的东西将使你无路可走。这是一个组合学的问题。AFAIK在.NET框架中没有预先为您解决的组合学问题,因此您必须实现正确的算法。如果您陷入困境,就会有一些解决方案,例如http://www.codeproject.com/KB/recipes/Combinatorics.aspx,您可以在那里查看源代码,看看您需要做什么。
发布于 2009-10-19 11:04:23
好吧..。
second.Length
first和second是字符串,为什么不使用first.Length和second?作为一个附带的问题,我不认为这个方法能解决问题,恐怕.
https://stackoverflow.com/questions/1588050
复制相似问题