src/2018/day-01.lisp @ a18b7db936b8

2019/01
author Steve Losh <steve@stevelosh.com>
date Sun, 01 Dec 2019 11:39:22 -0500
parents a19c9e1fd077
children 5b5c61ad8d2b
(defpackage :advent/2018/01 #.cl-user::*advent-use*)
(in-package :advent/2018/01)


(define-problem (2018 1) (data read-all)
  (values
    (summation data)
    (progn
      (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))))))

(1am:test test-2018/01
  (multiple-value-bind (part1 part2) (run)
    (1am:is (= 522 part1))
    (1am:is (= 73364 part2))))