src/2019/days/day-04.lisp @ 03d0cc3a648f
2019/14
author |
Steve Losh <steve@stevelosh.com> |
date |
Sat, 14 Dec 2019 12:47:15 -0500 |
parents |
cd781337a694 |
children |
182bdd87fd9e |
(defpackage :advent/2019/04 #.cl-user::*advent-use*)
(in-package :advent/2019/04)
(defun nondecreasing-digits-p (n)
(iterate
(for (a b) :on (digits n))
(while b)
(always (<= a b))))
(defun contains-duplicate-digit-p (n)
(iterate
(for (a b) :on (digits n))
(thereis (eql a b))))
(defun contains-offset-duplicate-digit-p (n)
(iterate
(for (a b c d) :on (cons nil (digits n)))
(while c)
(thereis (and (eql b c)
(not (eql a b))
(not (eql c d))))))
(define-problem (2019 4) (data read-line) ()
(destructuring-bind (lo hi) (mapcar #'parse-integer (str:split #\- data))
(iterate
(for i :from lo :to hi)
(for nondecreasing = (nondecreasing-digits-p i))
(for duplicate = (contains-duplicate-digit-p i))
(for offset-duplicate = (contains-offset-duplicate-digit-p i))
(counting (and nondecreasing duplicate) :into part1)
(counting (and nondecreasing offset-duplicate) :into part2)
(returning part1 part2))))