1
0
Fork 0

solve 2024 day 7

This commit is contained in:
sloane 2024-12-07 08:10:00 -05:00
parent 951f6c51b8
commit 6db60b7f34
Signed by: sloanelybutsurely
SSH key fingerprint: SHA256:8SBnwhl+RY3oEyQxy1a9wByPzxWM0x+/Ejc+sIlY5qQ
4 changed files with 78 additions and 2 deletions

View file

@ -2,7 +2,7 @@
| S | M | T | W | T | F | S |
| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
| [1] | [2] | [3] | [4] | [5] | [6] | 7 |
| [1] | [2] | [3] | [4] | [5] | [6] | [7] |
| 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| 15 | 16 | 17 | 18 | 19 | 20 | 21 |
| 22 | 23 | 24 | 25 | | | |
@ -13,3 +13,4 @@
[4]: ./lib/2024/4.ex
[5]: ./lib/2024/5.ex
[6]: ./lib/2024/6.ex
[7]: ./lib/2024/7.ex

45
2024/lib/2024/7.ex Normal file
View file

@ -0,0 +1,45 @@
import AOC
import AOC.Prelude
aoc 2024, 7 do
def p1(input) do
ops = [&Kernel.+/2, &Kernel.*/2]
calibration_result(input, ops)
end
def p2(input) do
ops = [&Kernel.+/2, &Kernel.*/2, &String.to_integer("#{&1}#{&2}")]
calibration_result(input, ops)
end
defp calibration_result(input, ops) do
input
|> read_equations()
|> Enum.filter(&solvable?(&1, ops))
|> Enum.map(&elem(&1, 0))
|> Enum.sum()
end
defp solvable?({answer, [acc | nums]}, ops), do: solvable?(nums, ops, answer, acc)
defp solvable?([], _ops, answer, answer), do: true
defp solvable?([], _ops, _answer, _acc), do: false
defp solvable?(_nums, _ops, answer, acc) when acc > answer, do: false
defp solvable?([n | rest], ops, answer, acc) do
Enum.any?(ops, &solvable?(rest, ops, answer, &1.(acc, n)))
end
## input
defp read_equations(input) do
input
|> lines()
|> Enum.map(&String.split(&1, ": "))
|> Enum.map(fn groups ->
[&String.to_integer/1, &ints/1]
|> Enum.zip_with(groups, &apply(&1, [&2]))
|> List.to_tuple()
end)
end
end

30
2024/lib/aoc/prelude.ex Normal file
View file

@ -0,0 +1,30 @@
defmodule AOC.Prelude do
@moduledoc """
Commonly used functions
"""
@doc """
Splits a String input into lists of lines.
Excludes any leading or trailing lines from the output list.
"""
@spec lines(String.t()) :: [String.t()]
def lines(str) do
String.split(str, "\n", trim: true)
end
@doc """
Takes a string containing multiple integers and returns a list of the parsed
integers.
The input is split on the given seperator. A single space is used if none is
provided.
"""
@spec ints(String.t()) :: [integer()]
@spec ints(String.t(), separator :: String.t()) :: [integer()]
def ints(str, separator \\ " ") do
str
|> String.split(separator, trim: true)
|> Enum.map(&String.to_integer/1)
end
end

View file

@ -15,7 +15,7 @@
| [2021] | **43/50** 🌟 | Elixir |
| [2022] | **14/50** 🌟 | Elixir, Haskell |
| [2023] | **19/50** 🌟 | Elixir, Haskell |
| [2024] | **12/50** 🌟 | Elixir |
| [2024] | **14/50** 🌟 | Elixir |
| **Total** | **162** 🌟| |
[2015]: ./2015