about summary refs log tree commit diff stats
path: root/js/games/nluqo.github.io/~bh/61a-pages/Lib/maze.scm
blob: cddce36e5632d13031d2839fb4020e8b49b5437c (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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
(define make-square list)

(define row car)

(define column cadr)

(define adas-maze
  (list
   (make-square 1 3) (make-square 1 4)
   (make-square 2 1) (make-square 2 2) (make-square 2 4)
   (make-square 3 1) (make-square 3 4) (make-square 3 5)
   (make-square 4 1) (make-square 4 2) (make-square 4 4)
   (make-square 5 2) (make-square 5 3) (make-square 5 4)))

(define (neighbors square)
  (list (make-square (- (row square) 1) (column square))
	(make-square (+ (row square) 1) (column square))
	(make-square (row square) (- (column square) 1))
	(make-square (row square) (+ (column square) 1))))

(define (find-path start goal maze)
  (try-paths (list (list start)) goal maze))

(define (try-paths paths goal maze)
  (define (try-loop p)
    (cond ((null? p)
	   (try-paths (extend-all-paths paths maze)
		      goal
		      maze))
	  ((complete? goal (car p))
	   (car p))
	  (else (try-loop (cdr p)))))
  (try-loop paths))

(define (complete? goal path)
  (same-square? goal (car path)))

(define (same-square? s1 s2)
  (and (= (row s1) (row s2))
       (= (column s1) (column s2))))

(define (extend-all-paths paths maze)
  (if (null? paths)
      '()
      (append (extend-path (car paths)
			   (neighbors (car (car paths)))
			   maze)
	      (extend-all-paths (cdr paths) maze))))

(define (extend-path path neighbors maze)
  (cond ((null? neighbors) '())
  	((allowed-extension? (car neighbors) maze)
   	 (cons (cons (car neighbors) path)
	       (extend-path path (cdr neighbors) maze)))
  	(else (extend-path path (cdr neighbors) maze))))

(define (allowed-extension? square maze)
  (square-in-list? square maze))

(define (square-in-list? square lst)
  (cond ((null? lst) #f)
	((same-square? square (car lst)) #t)
	(else (square-in-list? square (cdr lst)))))