Prolog: permutations check and multiple answers
- by Adrian
Continuing to learn prolog, I'm trying to write a permutation(L1, L2) predicate. It should return true, only if L1 can be made up of all elements in L2. My code so far is the following:
permutation([], []).
permutation([H|T], L2) :- remove(L2, H, R), permutation(T, R).
Assuming that the predicate remove(L1, X, R) functions correctly, and it removes X from L1, I do not get correct results:
?- permutation([1],[1]).
true ;
false.
?- permutation([1, 2],[1]).
true ;
false.
?- permutation([1, 2],[1, 2]).
true ;
false.
?- permutation([1],[1, 2]).
false.
What am I missing.
Subquestion: What happens when the remove predicate returns two answers? My implementation returns the new, correct list, and then after pressing ; it returns the original list. Which answer does permutation predicate use?
?- remove([1,2,3], 3, R).
R = [1, 2] ;
R = [1, 2, 3].