blob: 2cb2f3f6285fc1028699825f91f883fa4a1caea8 (
plain) (
blame)
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
40
41
42
43
44
45
46
47
48
49
50
|
(define datum car)
(define children cdr)
(define make-tree cons)
(define (city x) (make-tree x '()))
(define (leaf? x) (null? (children x)))
(define world
(make-tree
'earth
(list (make-tree
'united-states
(list (make-tree
'california
(list (city 'berkeley)
(city 'san-francisco)
(city 'palo-alto)
(city 'oakland)))
(make-tree
'massachusetts
(list (city 'cambridge)
(city 'amherst)
(city 'boston)
(city 'sudbury)))
(make-tree
'new-york
(list (city 'new-york)))))
(make-tree
'france
(list (city 'paris)
(city 'lyon)
(city 'marseilles))))))
(define (find-place place tree)
(cond ((eq? place (datum tree)) (cons (datum tree) '()))
((leaf? tree) '())
(else (let ((try (find-subtree place (children tree))))
(if (not (null? try))
(cons (datum tree) try)
'())))))
(define (find-subtree place nodes)
(if (null? nodes)
'()
(let ((try (find-place place (car nodes))))
(if (not (null? try))
try
(find-subtree place (cdr nodes))))))
|