【发布时间】:2011-08-18 05:42:05
【问题描述】:
更新: 组合学和未排序最终是我所需要的。 下面的链接很有帮助:
http://msdn.microsoft.com/en-us/library/aa289166(v=vs.71).aspx
http://www.codeproject.com/Articles/21335/Combinations-in-C-Part-2
问题
给定一个包含 N 个符号的列表,说 {0,1,2,3,4...}
以及这些的NCr组合
例如。 NC3 将生成:
0 1 2
0 1 3
0 1 4
...
...
1 2 3
1 2 4
etc...
对于第 i 个组合 (i = [1 .. NCr]),我想确定一个符号是否是它的一部分。
Func(N, r, i, s) = True/False or 0/1
例如。从上面继续
第一个组合包含 0 1 2 但不包含 3
F(N,3,1,"0") = TRUE
F(N,3,1,"1") = TRUE
F(N,3,1,"2") = TRUE
F(N,3,1,"3") = FALSE
可能有帮助或相关的当前方法和技巧。
与矩阵的关系
对于 r = 2 例如。 4C2 组合是二维矩阵的上半部分(或下半部分)
1,2 1,3 1,4
----2,3 2,4
--------3,4
对于 r = 3,它是 3D 矩阵或立方体的角 对于 r = 4 它是 4D 矩阵的“角”,依此类推。
另一个关系
理想情况下,解决方案的形式类似于以下问题的答案:
Calculate Combination based on position
长度为r的组合列表中的第n个组合(允许重复),可以计算第i个符号
使用整数除法和余数:
n/r^i % r = (0 代表第 0 个符号,1 代表第 1 个符号……等等)
例如,对于 3 个符号的第 6 个组合,第 0 个第 1 个和第 2 个符号是:
i = 0 => 6 / 3^0 % 3 = 0
i = 1 => 6 / 3^1 % 3 = 2
i = 2 => 6 / 3^2 % 3 = 0
第 6 个梳子将是 0 2 0
我需要类似的东西,但不允许重复。
感谢您到目前为止关注这个问题:]
凯文。
【问题讨论】:
-
或许添加
homework标签 -
@Amit 你为什么认为这是家庭作业?
-
问题交叉发布在math.SE。 (所以我在这里交叉发布了我的答案。:p 有更多代码,没有 TeX 标记。)
-
感谢您的接受。我很高兴它有帮助。
标签: algorithm function combinations combinatorics