π π€ π 𧑠π π π β€οΈ
Solutions for the AoC 2020 puzzles, written in 25 different programming languages.
- π Assembly Languages
- π€ Shell Scripting Languages
- π Database Languages
- 𧑠Mathematical Languages
- π Functional Languages
- π System Programming Languages
- π Web Application Languages
- β€οΈ General-Purpose Languages
Day | Puzzle | Language | Reference | Solution |
---|---|---|---|---|
1 | Report Repair | π x86-32 | day1.py | Β day1.s |
2 | Password Philosophy | π€ Bash | day2.py | Β day2.sh |
3 | Toboggan Trajectory | π€ PowerShell | day3.py | Β day3.ps1 |
4 | Passport Processing | π PostgreSQL | day4.py | Β day4.sql |
5 | Binary Boarding | 𧑠Prolog | day5.py |  day5.pl |
6 | Custom Customs | 𧑠Octave | day6.py |  day6.m |
7 | Handy Haversacks | 𧑠R | day7.py |  day7.R |
8 | Handheld Halting | π Haskell | day8.py | Β day8.hs |
9 | Encoding Error | π F# | day9.py | Β day9.fsx |
10 | Adapter Array | π Scala | day10.py | Β day10.scala |
11 | Seating System | π Nim | day11.py | Β day11.nim |
12 | Rain Risk | π C | day12.py | Β day12.c |
13 | Shuttle Search | π C++ | day13.py | Β day13.cpp |
14 | Docking Data | π Go | day14.py | Β day14.go |
15 | Rambunctious Recitation | π Rust | day15.py | Β day15.rs |
Instead of installing 25 toolchains, simply run each solution with Docker
export DAY=1
docker build -f ./docker/day${DAY}/Dockerfile -t day${DAY} .
docker run --rm -it day${DAY}
Input files must have LF line endings, which should be the default on checkout, if not, fix that with
dos2unix data/*.txt
Solutions are licensed under MIT. File icons are licensed under CC BY-SA 4.0 and authored by vscode-icons.
This section holds a brief description on how I experienced each day.
I guess I can't blame Assembly for not being user-friendly, right? Parsing a simple list of numbers was a nightmare. Printing them, even more. And I hope nobody sees that I abused stack pointers for my loop counters. Apart from that, I am really glad that my solution fits into a 32 bit register. I wouldn't have known what to do if it didn't.
I hated this.
A language where x=1
is not the same as x = 1
should not exist in this world.
And what special magic is $IFS
after all?
And when do I use single brackets, double brackets, braces or some other magic for my conditionals?
Very inconsistent and ugly.
Will chose Assembly over Bash next time.
Although I hated to use -eq
for simple comparisons, this looks much nicer than I initially expected.
Can we please stop writing Bash scripts and use PowerShell from now on?
It's also really cool that one can call .NET library functions from PowerShell.
Parsing a file into a table was the only challenge here. I am glad that I found this window function magic. The rest was easy. Oh, and I briefly looked into the Perl scripting mode for parsing stuff. However, I am so embarrassed by Perl that I don't even dare to commit that part.
Just declaring the conditions to find the non-consecutive item in a list - in a mathematical way - and having Prolog figuring out how to solve that was a marvelous experience. Would code again.
While I didn't like the syntax, the standard library provided enough functions to write this in a very clean way.
I hated to have lists, arrays and all this inconsistent indexing magic. Plus, I know that loops are slow, but, if the language doesn't give me a nice interface to write this in a functional way, what do you expect me to do?
Very consistent and mighty once you get used to all the special characters in the syntax. However, it's a pity that you are forced to write everything in a functional way. This isn't the best way of thinking for every problem.
If I would just have written normal loops instead of a recursive solution, I would have written a recursive solution instead of normal loops.
It feels very natural that one can write function chains from left to right.
Although, I think the standard library has much less functions compared to Haskell.
For one, missed itertools.groupby
from Python here.
This took some time to write, but it was worth it. It is fantastic to have code that is as readable as Python but compiles to fast machine code at the end of the day. Sadly, the compiler messages weren't very helpful when learning Nim and the documentation could be better. And I hate macro magic. Nevertheless, a great language.
Parsing the input was the only real challenge here, once again. Apart from that, well, it's just C.
Thanks to __int128
for saving my algorithm.
Plus, I learned that a % b
returns different results in Python and C++.
I was missing list comprehensions and tuple unpacking a lot here.
And that there is no argmax()
or enumerate()
.
And I hated that there is no .split(",")
function to parse comma-separated lists easily.
I probably code too much Python.
Good experience overall, I liked it. Go has a very well-designed standard library with plenty of utility functions. Only the syntax when appending to slices seemed a bit odd at first.
The better C++, but I still don't like the syntax.
All those unwrap()
calls mixed with *
and &
characters makes the code hard to read.
Moreover, I missed that I can not easily slice vectors but have to use e.g. split_last()
instead.