Skip to content

Instantly share code, notes, and snippets.

@emgullufsen
Created September 23, 2020 06:16
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save emgullufsen/181dbdf34ee9492ce0d831acc960cfb0 to your computer and use it in GitHub Desktop.
Save emgullufsen/181dbdf34ee9492ce0d831acc960cfb0 to your computer and use it in GitHub Desktop.
;; eg
;; sicp 3.3.3 - 2D tables
;; exercise 3.25 done baby!
(define (assoc key records)
(cond ((null? records) false)
((equal? key (caar records)) (car records))
(else (assoc key (cdr records)))))
(define (make-subtable keys value)
(if (null? (cdr keys))
(cons (car keys) value)
(list (car keys) (make-subtable (cdr keys) value))))
(define (make-table)
(let ((local-table (list '*table*)))
(define (lookup keys)
(let lookup-helper ((k keys) (t local-table))
(let ((rec (assoc (car k) (cdr t))))
(if rec
(if (null? (cdr k))
(cdr rec)
(lookup-helper (cdr k) rec))
false))))
(define (insert! keys value)
(let insert!-helper ((k keys) (t local-table))
(let ((rec (assoc (car k) (cdr t))))
(if rec
(if (null? (cdr k))
(set-cdr! rec value)
(insert!-helper (cdr k) rec))
(set-cdr! local-table (cons (make-subtable keys value) (cdr local-table)))))))
(define (dispatch m)
(cond ((eq? m 'lookup-proc) lookup)
((eq? m 'insert-proc!) insert!)
(else (error "Unknown operation -- TABLE" m))))
dispatch))
(define operation-table (make-table))
(define get (operation-table 'lookup-proc))
(define put (operation-table 'insert-proc!))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment