我想弄清楚如何生成集合列表,其中每个集合的长度为N,每个集合的总和为X.获取每个集合的总和为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.
任何指针?
完美!我删除了“链(List,#<)”,因为我正在查找所有加总为Sum的列表,而不仅仅是有序列表。我使用代码解决了DropQuest 2012的第1章:https://github.com/seanhagen/DropQuest-2012-Chapter-1-Prolog-Solver –