src/2018/main.lisp @ ff5234e0e329

Clean up
author Steve Losh <steve@stevelosh.com>
date Sat, 01 Dec 2018 15:26:07 -0500
parents bc917916aa2b
children 388494359561
(in-package :advent)

;;;; Utils --------------------------------------------------------------------
(defmacro define-problem ((day part) (data-symbol reader) &body body)
  (let ((function-name (symb 'day- day '/ part)))
    `(defun ,function-name ()
       (let ((,data-symbol (,reader ,(format nil "data/2018/~2,'0D.txt" day))))
         ,@body))))


;;;; Problems -----------------------------------------------------------------
(define-problem (1 1) (data read-all-from-file)
  (summation data))

(define-problem (1 2) (data read-all-from-file)
  (setf (cdr (last data)) data) ; make data a circular list for easy looping
  (iterate
    (with seen = (make-hash-set :initial-contents '(0)))
    (for number :in data)
    (summing number :into frequency)
    (if (hset-contains-p seen frequency)
      (return frequency)
      (hset-insert! seen frequency))))