2019/04
author |
Steve Losh <steve@stevelosh.com> |
date |
Wed, 04 Dec 2019 12:04:52 -0500 |
parents |
5b5c61ad8d2b |
children |
(none) |
(defpackage :advent/2018/01 #.cl-user::*advent-use*)
(in-package :advent/2018/01)
(define-problem (2018 1) (data read-all) (522 73364)
(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))))))