fd048651b6
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@55 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
46 lines
671 B
Plaintext
46 lines
671 B
Plaintext
|
|
:- object(quick(_Order)).
|
|
|
|
|
|
:- info([
|
|
authors is 'Paulo Moura',
|
|
version is 1.0,
|
|
date is 2000/4/22,
|
|
parnames is ['Order'],
|
|
comment is '.',
|
|
source is 'Example adopted from the Francis G. McCabe L&O documentation.']).
|
|
|
|
|
|
:- public(sort/2).
|
|
:- mode(sort(+list, -list), one).
|
|
|
|
|
|
sort([], []).
|
|
|
|
sort([X| L], S):-
|
|
split(L, X, L1, L2),
|
|
sort(L1, S1),
|
|
sort(L2, S2),
|
|
app(S1, [X| S2], S).
|
|
|
|
|
|
split([], _, [], []).
|
|
|
|
split([D| L], X, [D| L1], L2):-
|
|
parameter(1, Order),
|
|
Order::less(D, X),
|
|
!,
|
|
split(L, X, L1, L2).
|
|
|
|
split([D| L], X, L1, [D| L2]):-
|
|
split(L, X, L1, L2).
|
|
|
|
|
|
app([], L, L).
|
|
|
|
app([H| T], L, [H| T2]) :-
|
|
app(T, L, T2).
|
|
|
|
|
|
:- end_object.
|