:- pred ff. :- pred append(list(int),list(int),list(int)). :- pred leq(int,int,bool). :- pred adt_new1(list(int),list(int),bool). :- mode append(in,in,out). :- mode leq(in,in,out). :- mode adt_new1(in,in,out). adt_new1([],[A|B],C) :- C=:=0. adt_new1([A|B],[],C) :- C=:=0. adt_new1([],[],A) :- A=:=1. adt_new1([A|B],[C|D],E) :- E=:=0, C-A>=1. adt_new1([A|B],[C|D],E) :- E=:=0, C-A=< -1. adt_new1([A|B],[C|D],E) :- F=:=E, A=C, adt_new1(B,D,F). append([],A,A). append([A|B],C,[A|D]) :- append(B,C,D). ff :- A=:=1, append(B,[C],D), append(D,E,F), append(B,[C|E],G), adt_new1(F,G,A).