-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathStack.hs
More file actions
39 lines (31 loc) · 722 Bytes
/
Copy pathStack.hs
File metadata and controls
39 lines (31 loc) · 722 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
-- From Simon Peyton-Jones's "A taste of haskell"
module Stack(Stack,
-- swap1,
swap2,
swap3,
swap4,
swap5) where
type Stack w = [w]
-- swap1 :: Stack w -> Stack w
-- swap1 [] = []
-- swap1 (w : []) = w : []
-- swap1 (w1 : w2 : ws) = w2 : w1 : ws
swap2 :: Stack w -> Stack w
swap2 [] = []
swap2 [w] = [w]
swap2 (w1 : w2 : ws) = w2 : w1 : ws
swap3 :: Stack w -> Stack w
swap3 (w1 : w2 : ws) = w2 : w1 : ws
swap3 ws = ws
swap4 :: Stack w -> Stack w
swap4 ws = case ws of
[] -> []
[w] -> [w]
(w1:w2:ws) -> w2:w1:ws
swap5 :: Stack w -> Stack w
swap5 ws = case ws of
(w1:w2:ws) -> w2:w1:ws
ws -> ws
-- type TS = Stack Int
-- prop_swap1 :: TS -> Bool
-- prop_swap1 s = swap1 (swap1 s) == s