-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathhelpers.tex
More file actions
34 lines (30 loc) · 804 Bytes
/
helpers.tex
File metadata and controls
34 lines (30 loc) · 804 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
\chapter{Familiar Helpers}\label{helpers}
The auxiliaries below are used in the implementation of \alphakanrensp in Chapter~\ref{akimplchapter}.
\schemedisplayspace
\begin{schemedisplay}
(define get
(lambda (x s)
(cond
((assq x s) => cdr)
(else x))))
(define assp
(lambda (p s)
(cond
((null? s) #f)
((p (car (car s))) (car s))
(else (assp p (cdr s))))))
\end{schemedisplay}
\begin{schemedisplay}
(define filter
(lambda (p s)
(cond
((null? s) '())
((p (car s)) (cons (car s) (filter p (cdr s))))
(else (filter p (cdr s))))))
(define remove-duplicates
(lambda (s)
(cond
((null? s) '())
((memq (car s) (cdr s)) (remove-duplicates (cdr s)))
(else (cons (car s) (remove-duplicates (cdr s)))))))
\end{schemedisplay}