Merge branch 'master' of https://github.com/FFPiHaskell/slides
This commit is contained in:
commit
47eaf5d8b7
32
exampleCode/lecture8/sort.hs
Normal file
32
exampleCode/lecture8/sort.hs
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
module Main where
|
||||||
|
|
||||||
|
import Data.List
|
||||||
|
import Test.QuickCheck
|
||||||
|
|
||||||
|
-- Sorting twice changes nothing
|
||||||
|
prop_idempotency :: Ord a => [a] -> Bool
|
||||||
|
prop_idempotency xs = qsort xs == qsort (qsort xs)
|
||||||
|
|
||||||
|
-- Sorting doesn't change the length
|
||||||
|
prop_len :: Ord a => [a] -> Bool
|
||||||
|
prop_len xs = length xs == length (qsort xs)
|
||||||
|
|
||||||
|
-- Sorted result is a permutation of input
|
||||||
|
prop_perm :: Ord a => [a] -> Bool
|
||||||
|
prop_perm xs = (qsort xs) `elem` (permutations xs)
|
||||||
|
|
||||||
|
-- Sorting produces sorted list
|
||||||
|
prop_sort :: Ord a => [a] -> Bool
|
||||||
|
prop_sort = isSorted . qsort
|
||||||
|
where
|
||||||
|
isSorted :: Ord a => [a] -> Bool
|
||||||
|
isSorted [] = True
|
||||||
|
isSorted [x] = True
|
||||||
|
isSorted (x:y:zs) = (x <= y) && isSorted (y:zs)
|
||||||
|
|
||||||
|
qsort :: Ord a => [a] -> [a]
|
||||||
|
qsort [] = []
|
||||||
|
qsort (p:xs) = (qsort lesser) ++ p:(qsort greater)
|
||||||
|
where
|
||||||
|
lesser = filter (< p) xs
|
||||||
|
greater = filter (>= p) xs
|
BIN
lecture7.pdf
BIN
lecture7.pdf
Binary file not shown.
Loading…
Reference in New Issue
Block a user