day 7 part 1 in common lisp

This commit is contained in:
cow 2022-12-22 03:30:04 -05:00
parent dab8d182ee
commit c597155e86
3 changed files with 1148 additions and 9 deletions

1
common-lisp/day-7/input.txt Symbolic link
View file

@ -0,0 +1 @@
../../input/day-7.txt

View file

@ -1,5 +1,19 @@
#!/usr/bin/env -S sbcl --script #!/usr/bin/env -S sbcl --script
;; Copyright (C) 2022
;; This program is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
(require 'asdf) (require 'asdf)
(require 'cl-ppcre) (require 'cl-ppcre)
(require 'str) (require 'str)
@ -44,15 +58,24 @@
(depth p (incf depth)) (depth p (incf depth))
depth)) depth))
(defun size (dir)
(with-accessors ((files files)
(subdirs subdirs))
dir
(let ((files-sum (apply '+ (mapcar 'cdr files)))
(subdirs-sum (apply '+ (mapcar 'size (mapcar 'cdr subdirs)))))
(+ files-sum subdirs-sum))))
(defmethod print-object ((obj dir) stream) (defmethod print-object ((obj dir) stream)
(format stream (format stream "<dir ~a>" (name obj)))
"~&name: ~a~%parent: ~a~%depth: ~a~%subdirs: ~a~%files: ~a ~&"
(name obj) (defun walk (dir &optional visited)
(if (> (depth obj) 0) (with-accessors ((subdirs subdirs))
(name (parent obj))) dir
(depth obj) (push dir visited)
(files obj) (iter (iter:for (_ . subdir) in subdirs)
(subdirs obj))) (setq visited (walk subdir visited)))
visited))
(defclass fs () (defclass fs ()
((root ((root
@ -97,7 +120,7 @@
((str:digit? (nth 0 parts)) ((str:digit? (nth 0 parts))
(iter:collect (list 'file (nth 1 parts) (parse-integer (nth 0 parts)))))))) (iter:collect (list 'file (nth 1 parts) (parse-integer (nth 0 parts))))))))
(defun solution-part-1 (events) (defun run-commands (events)
(iter (iter:with fs = (make-instance 'fs)) (iter (iter:with fs = (make-instance 'fs))
(iter:for event in events) (iter:for event in events)
(let* ((type (car event)) (let* ((type (car event))
@ -113,3 +136,17 @@
((equal type 'file) ((equal type 'file)
(touch cwd dir-or-file-name size)))) (touch cwd dir-or-file-name size))))
(iter:finally (return fs))))) (iter:finally (return fs)))))
(defun solution-part-1 (fs)
(apply '+ (remove-if-not (lambda (size)
(<= size 100000))
(mapcar 'size (walk (root fs))))))
(defun run-part-1 (input)
(let* ((events (parse-input input))
(fs (run-commands events)))
(solution-part-1 fs)))
(assert (= (run-part-1 (uiop:read-file-lines "example.txt")) 95437))
(assert (= (run-part-1 (uiop:read-file-lines "input.txt")) 1084134))

1101
input/day-7.txt Normal file

File diff suppressed because it is too large Load diff