首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Python itertools.combinations的结果

Python itertools.combinations的结果
EN

Stack Overflow用户
提问于 2011-12-26 10:56:25
回答 1查看 23.5K关注 0票数 11

我没有从标题中的函数中得到多少结果,所以我希望得到你的帮助。

查看Docs http://docs.python.org/library/itertools.html#itertools.combinations,结果的数量应该是

返回的项目数为n!/ r!/(N)!当0 <= r <= n或0当r>n时。

它适用于这里的例子

组合(‘ABCD’,2) - AB AC AD BC BD CD

因为n!/ r!/(N)!= 4!/ 2!/ 2!=6

但如果我试着

代码语言:javascript
运行
复制
combinations('ABCDEF', 3) --> AB AC AD AE AF BC BD BE BF CD CE CF DE DF EF

我得到了这15个结果。但n / r /(N)= 6 / 3 / (6-3) = 720 /6/6= 20

因此: Python告诉我我应该有20个结果,但我得到了15个结果。

你能帮我理解我错过了什么吗?也许在我的数学里,这个公式应该是对的,就像在Wikipedia Combination entry里一样。

谢谢你,P。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-12-26 11:04:15

itertools.combinations应该返回一个包含20个项的迭代器:

代码语言:javascript
运行
复制
In [40]: len(list(itertools.combinations('ABCDEF',3)))
Out[40]: 20

请注意,

代码语言:javascript
运行
复制
In [41]: len(list(itertools.combinations('ABCDEF',2)))
Out[41]: 15

以及公布的输出

代码语言:javascript
运行
复制
combinations('ABCDEF', 3) --> AB AC AD AE AF BC BD BE BF CD CE CF DE DF EF

只显示两个字母的组合。看来你计算的是combinations('ABCDEF', 2),而不是combinations('ABCDEF', 3)

票数 22
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8635073

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档