Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fjebaker/advent-of-code-2023
Solutions to Advent of Code 2023 in CHICKEN Scheme.
https://github.com/fjebaker/advent-of-code-2023
advent-of-code advent-of-code-2023 aoc-2023 chicken-scheme scheme
Last synced: 20 days ago
JSON representation
Solutions to Advent of Code 2023 in CHICKEN Scheme.
- Host: GitHub
- URL: https://github.com/fjebaker/advent-of-code-2023
- Owner: fjebaker
- License: mit
- Created: 2023-12-01T22:22:53.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-12-13T19:01:38.000Z (about 1 year ago)
- Last Synced: 2024-12-21T18:42:36.480Z (23 days ago)
- Topics: advent-of-code, advent-of-code-2023, aoc-2023, chicken-scheme, scheme
- Language: Scheme
- Homepage:
- Size: 31.3 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# advent-of-code-2023
Advent of Code 2023 in CHICKEN Scheme (until I can't do it anymore and fallback to something nicer like C++)!
## Lessons from each day
- 01: Recursion makes my brain hurty
- 02: `defstruct` is a life saver and slowly learning how to use the standard libs
- 03: hash tables are in `(srfi 69)`, and `(chicken plist)` is for `(symbol value)` list pairs. Also `printf` is cool
- 04: Vectors are fixed length lists with $O(1)$ read write operations
- 05: Life would be easier if you always treat ranges as `(start, end)` and not `(start, length)`. Also why loop when you can `(map)`!
- 06: `(floor)` and `(ceiling)` also do float to integer parsing, but then need to recover exactness with `(inexact->exact)`. Also `(map)` accepts as many lists as function airity!
- 07: `(plist)` is useful but the way you have to pass the symbol around instead of e.g. the list itself is counter-intuitive. Also I can't work out how to do `if any` on a list?
- 08: `(chicken irregex)` are IrRegular Expressions, that are also constructed from s-expressions.
- 09: `(define ((curry f x) y) (f x y))` is *chef's kiss*. Also SRFI-1 has an `every` that does what I wanted with `all/any`!
- 10: it might be better to use data structures instead of remembering if it's `car` or `cdr` next. [Pick's Theorem](https://en.wikipedia.org/wiki/Pick%27s_theorem) is very cool!
- 11: i didn't really learn anything new from this one
- 12: memoization is easy but you need the egg. i can't work out a nice tail-call recursive pattern for solution though, since i need to (maybe) add the result to a variable (twice) and then return that