module GeomAlg.External.Sort(sortLe, sort) where
sortLe :: (a -> a -> Bool) -> [a] -> [a]
sortLe le l = tmsort le l
sort :: (Ord a) => [a] -> [a]
sort l = tmsort (<=) l
tmsort _ [] = []
tmsort _ [x] = [x]
tmsort le (x:xs) = msort le (upSeq le xs [x])
upSeq _ [] xs = [reverse xs]
upSeq le (y:ys) xxs@(x:xs) =
if le x y then
upSeq le ys (y:xxs)
else
reverse xxs : upSeq le ys [y]
msort _ [xs] = xs
msort le xss = msort le (mergePairs le xss)
mergePairs le (xs:ys:xss) = merge le xs ys : mergePairs le xss
mergePairs _ xss = xss
merge le xxs@(x:xs) yys@(y:ys) =
if le x y then
x:merge le xs yys
else
y:merge le xxs ys
merge _ [] yys = yys
merge _ xxs [] = xxs