Я пытаюсь понять, как создать список наборов, где каждый набор имеет длину 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.
Любые указатели?