====== Diff quicksort ====== {{tag>lists sorting}} ===== Description ===== Quicksort using difference-list **Source**: The Art of Prolog ===== Download ===== Program source code: {{diff_quicksort.pl}} ===== Listing ===== /* quicksort(List,Sortedlist) :- Sortedlist is an ordered permutation of list. */ :- op(40,xfx,\). quicksort(Xs,Ys) :- quicksort_dl(Xs,Ys\[]). quicksort_dl([X|Xs],Ys\Zs) :- partition(Xs,X,Littles,Bigs), quicksort_dl(Littles,Ys\[X|Ys1]), quicksort_dl(Bigs,Ys1\Zs). quicksort_dl([],Xs\Xs). partition([X|Xs],Y,[X|Ls],Bs) :- X =< Y, !, partition(Xs,Y,Ls,Bs). partition([X|Xs],Y,Ls,[X|Bs]) :- X > Y, !, partition(Xs,Y,Ls,Bs). partition([],Y,[],[]). % Program 15.4: Quicksort using difference-lists. ===== Comments =====