我试图弄清楚如何生成一个集合列表,其中每个集合的长度为 N,每个集合的总和为 X。
我找到了这段代码:
num_split(0,[]).
num_split(N, [X | List]):-
between(1,N,X),
plus(X,Y,N),
num_split(Y,List).
我可以使用它来获取总和 X 的集合列表:
num_split(6,List),length(List,5).
List = [1, 1, 1, 1, 2] ;
List = [1, 1, 1, 2, 1] ;
List = [1, 1, 2, 1, 1] ;
List = [1, 2, 1, 1, 1] ;
List = [2, 1, 1, 1, 1] ;
false.
问题是这些都是排列,我正在寻找组合。我正在寻找的输出应该是这样的get_combos(Sum,Length,List)
:
get_combos(6,2,List).
List = [5,1];
List = [4,2];
List = [3,3];
false.
任何指针?